配置文件 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