美文网首页互联网开发手记
mybatis从使用到了解(三)_mybatis配置文件解读

mybatis从使用到了解(三)_mybatis配置文件解读

作者: YONGSSU的技术站点 | 来源:发表于2017-01-02 23:12 被阅读59次

    配置文件 config.xml

    <?xml version="1.0" encoding="UTF-8" ?>
    <!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
            "http://mybatis.org/dtd/mybatis-3-config.dtd">
    
    <configuration>
        <properties resource="config.properties">
        </properties>
        <typeAliases>
            <typeAlias alias="Student" type="com.yongssu.mybatis.demo1.Student"/>
        </typeAliases>
        <environments default="development">
            <environment id="development">
                <transactionManager type="JDBC"/>
                <dataSource type="POOLED">
                    <property name="driver" value="${driver}"/>
                    <property name="url" value="${url}"/>
                    <property name="username" value="${username}"/>
                    <property name="password" value="${password}"/>
                </dataSource>
            </environment>
        </environments>
        <mappers>
            <mapper resource="student.xml"/>
        </mappers>
    </configuration>
    
    

    config.properties

    
    driver=com.mysql.cj.jdbc.Driver
    url=jdbc:mysql://localhost:3306/test
    username=root
    password=123456
    

    properties

    引入config.properties配置文件,一些参数可以在config.properties中配置,而引入到config.xml中。

    typeAliases类型别名

    为java类型设置一个短的名字,减少类完全限定名的冗余。上面配置中利用Student来代替com.yongssu.mybatis.demo1.Student。
    也可以指定一个包名,然后通过在具体类中用@Alias注解来实现相同的配置。
    如下:

    <typeAliases>
        <package name="com.yongssu.mybatis.demo1"/>
    </typeAliases>
    

    然后

    @Alias("Student")
    public class Student{
    }
    

    配置环境(environments)

    在实际开发中,通常有开发、测试、生产环境多套环境,mybatis可以配置成适应多环境的。不过要注意的是,每个数据库对应一个SqlSessionFactory实例。及,如果想连接两个数据库,就需要创建两个SqlSessionFactory实例,每个数据库对应一个。
    可以通过环境参数将来指定具体的环境

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

    具体配置

     <environments default="development">
        <environment id="development">
            <transactionManager type="JDBC"/>
            <dataSource type="POOLED">
                <property name="driver" value="${driver}"/>
                <property name="url" value="${url}"/>
                <property name="username" value="${username}"/>
                <property name="password" value="${password}"/>
            </dataSource>
        </environment>
    <environments/>
    

    这里的关注点:

    • default="development"默认环境ID
    • id="development"每个environment元素定义的环境ID
    • 事务管理器
      mybatis中有两种类型的事务管理器,type="[JDBC|MANAGED]"
      1.JDBC-这个配置直接使用JDBC的提交和回滚设置,依赖于数据源得到的链接来管理事务。
      2.MANAGED-让容器来管理事务的整个生命周期。默认情况下会关闭链接,一些容器不希望这样,因此需要将closeConnection属性设置为false来阻止它默认的关闭行为。
    <transactionManager type="MANAGED">
      <property name="closeConnection" value="false"/>
    </transactionManager>
    

    注意 如果使用Spring+MyBatis,没有必要配置事务管理器,因为Spring模块会使用自带的管理器来覆盖前面的配置。

    • 数据源
      mybatis提供了三种内建的数据源类型(type="UNPOOLED|POOLED|JNDI")
      UNPOOLED —— 每次被请求时打开和关闭链接,每次都需要建立链接,对于没有性能要求的简单应用程序可以用。
      POOLED —— 数据库链接池,利用“池”的概念讲JDBC链接对象组织起来,避免每次都需要重新建立链接。是一种使得并发web应用快速响应请求的处理方式。
      JNDI —— 为了实现能在EJB或者应用服务器这类容器使用,容器可以集中或在外部配置数据源,然后放置一个JNDI上下文的引用。

    映射器(mappers)

    定义sql映射语句的配置文件。如

     <mappers>
        <mapper resource="student.xml"/>
    </mappers>
    

    指定了Student的sql映射文件为student.xml

    相关文章

      网友评论

        本文标题:mybatis从使用到了解(三)_mybatis配置文件解读

        本文链接:https://www.haomeiwen.com/subject/ajrgvttx.html