zoukankan      html  css  js  c++  java
  • mybatis学习总结-核心配置文件mybatis-config.xml

    http://ju.outofmemory.cn/entry/94634

    在 mybatis初体验 中,在mybatis-config.xml中有这样的配置:

        <!-- 对事务的管理和连接池的配置 -->  
        <environments default="development">  
            <environment id="development">  
                <transactionManager type="JDBC" />  
                <dataSource type="POOLED">  
                    <property name="driver" value="${jdbc.driverClassName}" />  
                    <property name="url" value="${jdbc.url}" />  
                    <property name="username" value="${jdbc.username}" />  
                    <property name="password" value="${jdbc.password}" />   
                </dataSource>  
            </environment>  
        </environments>

    从这可以看出,environments主要用于配置数据库相关,而且可以在里面配置多个environment。

    因为有这些场景:

    1)为了开发设置不同的数据库配置

    2)测试和生产环境数据库不同

    3)有多个数据库却共享相同的模式,即对不同的数据库使用相同的SQL映射

    我们可以配置几个数据库配置,我们可以这样:

     <!-- 对事务的管理和连接池的配置 -->  
        <environments default="oracle_jdbc">  
            <environment id="oracle_jdbc">  
                <transactionManager type="JDBC" />  
                <dataSource type="POOLED">  
                    <property name="driver" value="${jdbc.oracle.driverClassName}" />  
                    <property name="url" value="${jdbc.oracle.url}" />  
                    <property name="username" value="${jdbc.oracle.username}" />  
                    <property name="password" value="${jdbc.oracle.password}" />   
                </dataSource>  
            </environment>  
            
            <environment id="mysql_jdbc">  
                <transactionManager type="JDBC" />  
                <dataSource type="POOLED">  
                    <property name="driver" value="${jdbc.mysql.driverClassName}" />  
                    <property name="url" value="${jdbc.mysql.url}" />  
                    <property name="username" value="${jdbc.mysql.username}" />  
                    <property name="password" value="${jdbc.mysql.password}" />   
                </dataSource>  
            </environment> 
        </environments>

    用default指定默认的数据库链接:(这里默认oracle)

     <environments default="oracle_jdbc">

    我们每个数据库,对应一个SqlSessionFactory,可以明确的获取哪一个数据库的SqlSessionFactory。

    根据数据库环境,获取SqlSessionFactory:

    SqlSessionFactory factory = sqlSessionFactoryBuilder.build(reader, environment);
    SqlSessionFactory factory = sqlSessionFactoryBuilder.build(reader, environment,properties);

    我们的每个数据库信息都定义在environment中,我们看下这下面的配置:

    1.transactionManager

    示例配置:

    <transactionManager type="JDBC" />

    type取值范围:

    JDBC:简单的使用JDBC的提交和回滚设置,一览与从数据员得到的链接来管理事务范围

    MANAGED:这个配置几乎什么都没做,它从来不提交或回滚一个链接,而它让容器来管理事务的整个生命周期(比如spring、jee应用服务器的上下文)

    在默认情况下,MANAGED会关闭连接,如果有时候不希望这样时,可以从连接中停止它,将claseConnection属性设置为false:

    <transactionManager type="MANAGED">
      <property name="closeConnection" value="false"/>
    </transactionManager>

    2.dataSource

    用来配置基本的JDBC数据源连接信息

    示例配置:

    <dataSource type="POOLED">  
       <property name="driver" value="${jdbc.mysql.driverClassName}" />  
       <property name="url" value="${jdbc.mysql.url}" />  
       <property name="username" value="${jdbc.mysql.username}" />  
       <property name="password" value="${jdbc.mysql.password}" />   
    </dataSource>

    type取值范围:

    UNPOOLED:这个数据源的实现是每次被请求时打开和关闭连接。速度会有一些慢,适用于简单的应用程序。

    这种类型的数据源只需要配置下面的6种属性(最后一项为可选):

    driver JDBC驱动名
    url JDBC URL地址
    username 数据库用户名
    password 数据库密码
    defaultTransactionIsolationLevel 默认的链接事务隔离级别
    driver.encoding utf-8(可选项)

    POOLED:这是JDBC链接对象的数据源连接池的实现,用来避免创建新的链接实例时必要的连接和认证时间。适用于当前Web应用程序用来快速响应请求

    这种类型的数据源除了需要配置UNPOOLED中的基础配置外,还可以配置下面的内容:

    poolMaximumActiveConnections 在任意时间正在使用链接的数量
    poolMaximumIdleConnections 任意时间存在的空闲连接数
    poolMaximumCheckoutTime 在被强制返回之前,连接池中被检查的时间,默认值为20000毫秒
    poolTimeToWait 给连接池一个打印日志状态机会的低层次设置,还有重新尝试获取连接,这些情况往往会需要很长时间。为了避免连接池没有配置时静默失败。默认值20000毫秒
    poolPingQuery 发送到数据的侦测查询,用来验证连接是否正常工作,并且准备接受请求。默认为“NO PING QUERY SET”,这会引起许多数据库驱动连接由一个错误信息而导致失败
    poolPingEnabled 这是开启或禁用侦测查询,如果开启,必须用一个合法的SQL语句,设置poolPingQuery属性,默认值为false
    poolPingConnectionsNotUsedFor 用来配置poolPingQuery多长时间被调用一次。可以被设置匹配标准的数据库链接超时时间,来避免不必要的侦测。默认值0(也就是所有链接每一时刻都被侦测到,但仅仅当poolPingEnabled为true时适用)。

    JNDI:这个数据源是为了使用如Spring或应用服务器这类的容器,容器可以集中或在外部配置数据源,然后设置JNDI上下文的引用。

    这个数据源只需要配置两个属性:

    initial_context 用来从初始上下文中寻找环境(也就是initialContext.lookup(initial——context)),这是个可选属性,如果被忽略,那么data_source属性将直接以initialContext为背景再次寻找
    data_source 这是引用数据源实例位置的上下文的路径,它会以initial_context查询返回的环境为背景来查找,如果initial_context没有返回结果时,直接以初始上下文为环境来查找。

    和其他数据源配置类似,他可以通过名“env.”的前缀来直接向初始上下文发送属性,比如:

    env.encoding=UTF8
  • 相关阅读:
    Swift 泛型和闭包结合使用
    Swift中避免在多个文件中重复import相同的第三方包
    iOS AVAudioPlayer播放音频时声音太小
    python中装饰器的原理以及实现,
    python-网易云简单爬虫
    python模拟SQL语句操作文件
    python学习第二天-基本数据类型常用方法
    python学习第一天-语法学习
    iOS 出现错误reason: image not found的解决方案
    Swift as as!和as?的区别
  • 原文地址:https://www.cnblogs.com/manhuidhu/p/8358736.html
Copyright © 2011-2022 走看看