一。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>