文档章节

Configuration XML2

solverpeng
 solverpeng
发布于 2016/05/09 17:26
字数 1038
阅读 8
收藏 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

没有更多内容

加载失败,请刷新页面

加载更多

创建第一个react项目

sudo npm i -g create-react-app@1.5.2 create-react-app react-app cd react-apprm -rf package-lock.jsonrm -rf node_modules #主要是为了避免报错npm installnpm start......

lilugirl
55分钟前
1
0
在浏览器中进行深度学习:TensorFlow.js (八)生成对抗网络 (GAN)

Generative Adversarial Network 是深度学习中非常有趣的一种方法。GAN最早源自Ian Goodfellow的这篇论文。LeCun对GAN给出了极高的评价: “There are many interesting recent development...

naughty
今天
0
0
搬瓦工镜像站bwh1.net被DNS污染,国内打不开搬瓦工官网

今天下午(2018年10月17日),继搬瓦工主域名bandwagonhost.com被污染后,这个国内的镜像地址bwh1.net也被墙了。那么目前应该怎么访问搬瓦工官网呢? 消息来源:搬瓦工优惠网->搬瓦工镜像站b...

flyzy2005
今天
2
0
SpringBoot自动配置

本篇介绍下,如何通过springboot的自动配置,将公司项目内的依赖jar,不需要扫描路径,依赖jar的情况下,就能将jar内配置了@configuration注解的类,创建到IOC里面 介绍下开发环境 JDK版本1.8 spr...

贺小五
今天
3
0
命令行新建Maven多项目

参考地址 # DgroupId 可以理解为包名# DartifactId 可以理解为项目名mvn archetype:generate -DgroupId=cn.modfun -DartifactId=scaffold -DarchetypeArtifactId=maven-archetype-quickst......

阿白
今天
2
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部