美文网首页互联网开发手记
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