文档章节

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>

© 著作权归作者所有

共有 人打赏支持
上一篇: Mapper XML
下一篇: Configuration XML
solverpeng

solverpeng

粉丝 11
博文 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 v......

jingdor
2015/04/09
506
2
configure: error: xml2-config not found. Please check your libxml2 installation

安装php时的报错 checking libxml2 install dir... no checking for xml2-config path... configure: error: xml2-config not found. Please check your libxml2 installation. 检查是否安装......

bengozhong
2018/10/19
0
0
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

没有更多内容

加载失败,请刷新页面

加载更多

Linux Wireshark普通用户启动使用方案

当系统安装好Wireshark后请正常启动是否可以进行正常使用,如果不行请参考下列指导 向系统添加一个用户组 sudo groupadd wireshark //如提示此组存在可跳过 将指定用户添加到这个组中 sudo...

CHONGCHEN
今天
2
0
CSS 选择器参考手册

CSS 选择器参考手册 选择器 描述 [attribute] 用于选取带有指定属性的元素。 [attribute=value] 用于选取带有指定属性和值的元素。 [attribute~=value] 用于选取属性值中包含指定词汇的元素。...

Jack088
今天
2
0
数据库篇一

数据库篇 第1章 数据库介绍 1.1 数据库概述  什么是数据库(DB:DataBase) 数据库就是存储数据的仓库,其本质是一个文件系统,数据按照特定的格式将数据存储起来,用户可以对数据库中的数据...

stars永恒
今天
4
0
Intellij IDEA中设置了jsp页面,但是在访问页面时却提示404

在Intellij IDEA中设置了spring boot的jsp页面,但是在访问时,却出现404,Not Found,经过查找资料后解决,步骤如下: 在Run/Debug Configurations面板中设置该程序的Working Directory选项...

uknow8692
昨天
4
0
day24:文档第五行增内容|每月1号压缩/etc/目录|过滤文本重复次数多的10个单词|人员分组|

1、在文本文档1.txt里第五行下面增加如下内容;两个方法; # This is a test file.# Test insert line into this file. 分析:给文档后增加内容,可以用sed 来搞定;也可以用while do done...

芬野de博客
昨天
4
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部