文档章节

Configuration XML2

solverpeng
 solverpeng
发布于 2016/05/09 17:26
字数 1038
阅读 7
收藏 0
点赞 2
评论 0

一。environments

简介:Mybatis可以配置成适应多种环境,如开发,测试,生产环境。

需要注意的是,尽管可以配置多个环境,但每个SQLSessionFactory只能选其一,所以,如果想连接两个数据库,就需要创建两个SQLSessionFactory对象,每个数据库对应一个。

关键配置:

默认的环境id:如 default="development"

每个environment元素定义的环境id:如 id="development"

默认的环境和环境ID是自我解释的。可以使用喜欢的名称来命名,只要确定默认的要匹配其中之一。

事务管理器的配置:如 type="JDBC"

在Mybatis中有两种类型的事务管理器:

“JDBC”: 这个配置直接使用了JDBC的提交和回滚设置,它依赖于从数据源得到的连接来管理事务。

“MANAGED”:这个配置几乎什么都没做。它从来不提交或回滚一个连接,而是让容器来管理事务的整个生命周期。默认情况下,它会关闭连接,可以将closeConnection属性设置为false来阻止它默认的关闭行为。

如果使用 Spring+Mybatis,则没必要配置事务管理器,因为Spring会使用自带的事务管理来覆盖前面的配置。

数据源的配置:如 type="POOLED"

dataSource元素使用基本的JDBC数据源接口来配置JDBC连接对象的资源。

有三种内建的数据源类型(type="???")

UNPOOLED:无连接池

    这个数据源的实现是每次被请求时简单打开或关闭连接

    仅仅需要配置以下5中属性:

    driver url username password defaultTransactionIsolationLevel

POOLED:有连接池

    这种数据源的实现避免了创建新的连接时初始化和认证的时间。

    除 driver url username password defaultTransactionIsolationLevel 这些属性外,会有更多的属性来配置有连接池的的数据源:

    poolMaximumActiveConnections – 在任意时间可以存在的活动(也就是正在使用)连接数量,默认值:10
    poolMaximumIdleConnections – 任意时间可能存在的空闲连接数

    poolMaximumCheckoutTime – 在被强制返回之前,池中连接被检出(checked out)时间,默认值:20000 毫秒(即 20 秒)

    poolTimeToWait – 这是一个低层设置,如果获取连接花费的相当长的时间,它会给连接池打印日志并重新尝试获取一个连接的机会(避免在误配置的情况下一直安静的失败),默认值:20000 毫秒(即 20 秒)。

    poolPingQuery – 发送到数据的侦测查询,用来检验连接是否处在正常工作秩序中并准备接受请求。默认是“NO PING QUERY SET”,这会导致多数数据库驱动失败时带有一个恰当的错误消息。

    poolPingEnabled – 是否启用侦测查询。若开启,也必须使用一个可执行的 SQL 语句设置 poolPingQuery 属性(最好是一个非常快的 SQL),默认值:false。

    poolPingConnectionsNotUsedFor – 配置 poolPingQuery 的使用频度。这可以被设置成匹配标准的数据库连接超时时间,来避免不必要的侦测,默认值:0(即所有连接每一时刻都被侦测 — 当然仅当 poolPingEnabled 为 true 时适用)。

JNDI

任何第三方数据源:

需要实现接口:DataSourceFactory

UnpooledDataSourceFactory:可被用作父类来构建新的数据源适配器。

type="DataSourceFactory的实现类"。

二。databaseIdProvider

Mybatis可以根据不同的数据库厂商提供不同的语句,这种多厂商的支持是基于映射语句中的databaseId属性。

Mybatis会加载不带 databaseId属性和带有匹配当前数据库databaseId属性的所有语句。如果同时找到带有databaseId和不带databaseId的相同语句,则或者会被舍弃。

为支持多厂商特性,只要在mybatis-config.xml文件中加入 databaseIdProvider(type="DB_VENDOR")通过 DatabaseMetaData#getDatabaseProductName() 返回的字符串进行设置。

由于通常情况下这个字符串都非常长而且相同产品的不同版本返回不同的值,所以最好通过设置属性别名来使其变短。

<databaseIdProvider type="DB_VENDOR">
    <property name="MySQL" value="mysql"/>
    <property name="Oracle" value="oracle"/>
</databaseIdProvider>

© 著作权归作者所有

共有 人打赏支持
solverpeng

solverpeng

粉丝 10
博文 87
码字总数 40353
作品 0
朝阳
程序员
Linux centos 下PHP安装

PHP安装前,需先安装mysql(PHP需要调用mysql的库),另外需要检查系统是否安装了libxl等库的包以及其他环境所需要的包(LAMP环境部署时需要将把需要的包提前装好,否则不能正常进行LAMP环境...

chidongting
2016/06/27
0
0
Note, however, that nokogiri is not fully compatible with arbitrary

ruby 2.2 执行 gem install rails -v '4.2.0' -V 报错 IMPORTANT NOTICE: Building Nokogiri with a packaged version of libxml2-2.9.2 with the following patches applied: 0001-Revert-M......

jingdor
2015/04/09
450
2
LNMP编译安装遇到问题归总

LNMP编译安装遇到问题归总 1、错误:configure: error: freetype-config not found. 解决:yum install freetype-devel 2、错误:configure: error: libevent >= 1.4.11 could not be found......

boy461205160
2017/09/07
0
0
Ubuntu 12.04 编译安装 PHP 5.4.3

./configure 提示找不到 xml2-config ,但是 apt-get install libxml2 提示已经安装。 locate libxml2.so 也有结果。 看提示信息中有 xml2-config ,尝试了一下 apt-get install libxml2-de...

AiryLinus
2012/05/22
0
0
安装gitlab,nokogiri遇到的错误,大神们指点指点

Installing nokogiri 1.6.8 with native extensions Gem::Ext::BuildError: ERROR: Failed to build gem native extension. /usr/local/bin/ruby extconf.rb Using pkg-config version 1.1.7......

非技术专家群体
2016/07/19
354
3
Centos 安装 PHP 5.4.3 报 configure error xml2-config

参考:http://www.jsjtt.com/xitongyingyong/linux/17.html Centos 安装 PHP 5.4.3 报 configure error xml2-config not found. please check your libxml2 installation 错误 检查是否安装了......

小懒猫Mao
2016/03/11
7
0
安装 PHP 5.4.3 报 configure error xml2-config not found. please check your libxml2 installation 错误

检查是否安装了libxm包 [root@rh-linux software]# rpm -qa |grep libxml2 libxml2-2.6.26-2.1.12 libxml2-python-2.6.26-2.1.12 重新安装libxml2和libxml2-devel包, yum安装的时候发现新版本......

有功夫
2016/07/18
0
0
soap

wget http://cn2.php.net/distributions/php-5.4.38.tar.gz tar zxf php-5.4.38.tar.gz cd /ext/soap find / -name phpize /usr/bin/phpize find / -name 'php-config' ./configure --with-p......

cloves
2017/11/14
0
0
Linux PHP安装遇见的问题及解决方案

遇到的问题与解决方案 问题一: 报以下错误 ./configure以下错误发生 Sorry, I cannot run apxs. Possiblereasons follow: 1. Perl is not installed 2. apxs was not found. Try to pass th......

zhangguangyi
2017/05/18
0
0
configure: error: xml2-config not found. Please ch

configure: error: xml2-config not found. Please check your libxml2 installation 参考文章:http://blog.csdn.net/anljf/article/details/6981247 configure: error: xml2-config not fo......

天下杰论
2014/06/16
0
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

页面输出JSON格式数据

package com.sysware.utils;import java.io.IOException;import javax.servlet.ServletResponse;import org.apache.log4j.Logger;import com.sysware.SyswareConstant;pub......

AK灬
18分钟前
0
0
springCloud-2.搭建Eureka Client的使用

1.使用IDEA,Spring Initializr创建 2.填写项目资料 3.选择spring boot版本,插件选择Cloud Discovery→Eureka Discovery 4.选择保存地址 5.修改application.yml eureka: client: s...

贺小康
21分钟前
0
0
CenOS 6.5 RPM 安装 elasticsearch 6.3.1

下载 wget --no-check-certificate https://artifacts.elastic.co/downloads/elasticsearch/elasticsearch-6.3.1.rpm...

阿白
24分钟前
0
0
1.4 创建虚拟机&1.5 安装CentOS7&1.6 配置ip(上)&1.7 配置ip(下)

1.4 创建虚拟机 知识点 虚拟机网络链接模式 桥连 直接将虚拟网卡桥接到一个物理网卡上面。需要手工为虚拟系统配置IP地址、子网掩码,而且还要和宿主机器处于同一网段,这样虚拟系统才能和宿主...

小丑鱼00
30分钟前
0
0
TrustAsia(亚洲诚信)助力看雪2018安全开发者峰会

2018年7月21日,看雪2018安全开发者峰会在北京国家会议中心圆满落下帷幕。拥有18年悠久历史的老牌安全技术社区——看雪学院联手国内最大开发者社区CSDN,汇聚业内顶尖的安全开发者和技术专家...

亚洲诚信
32分钟前
0
0
Spring注解介绍

@Resource、@AutoWired、@Qualifier 都用来注入对象。其中@Resource可以以 name 或 type 方式注入,@AutoWired只能以 type 方式注入,@Qualifier 只能以 name 方式注入。 但它们有一些细微区...

lqlm
42分钟前
0
0
32位汇编在64位Ubuntu上的汇编和连接

本教程使用的操作系统是Ubuntu Linux 18.04 LTS版本,汇编器是GNU AS(简称as),连接器是GNU LD(简称ld)。 以下是一段用于检测CPU品牌的汇编小程序(cpuid2.s): .section .dataoutput...

ryanliue
51分钟前
0
0
CentOS系统启动报错Failed to mount /sysroot解决方法

xfs_repair -v -L /dev/dm-0

Mr_Tea伯奕
今天
1
0
美团点评云真机平台实践

背景 随着美团点评业务越来越多,研发团队越来越庞大,对测试手机的需求显著增长。这对公司来说是一笔不小的开支,但现有测试手机资源分配不均,利用率也非常有限,导致各个团队开发、测试过...

美团技术团队
今天
0
0
eclipse SVN 项目重新定位

SVN 重新定位 1.方法一 首先:在Eclipse中选择Windows-> Show View->others 就会出现【SVN资源库/SVN Repositories】,选中后,点击确认; 然后:选中原有的地址,选择【重新定位/Relocate】...

qimh
今天
1
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部