一、MyBatis核心配置文件层级关系
本文代码在 Mybatis初体验:一小时从入门到运行你的第一个应用 所构建的基础代码结构之上,进行修改。
-
MyBatis 的配置文件包含了会深深影响 MyBatis 行为的设置和属性信息。
-
配置文档的顶层结构如下:
二、MyBatis常用配置解析
1、environments标签
-
其中,事务管理器(transactionManager)类型有两种:
- JDBC:这个配置就是直接使用了JDBC 的提交和回滚设置,它依赖于从数据源得到的连接来管理事务作用域。
- MANAGED:这个配置几乎没做什么。它从来不提交或回滚一个连接,而是让容器来管理事务的整个生命周期。 例如:mybatis与spring整合后,事务交给spring容器管理。
-
其中,数据源(dataSource)常用类型有三种:
-
UNPOOLED:
这个数据源的实现只是每次被请求时打开和关闭连接。
-
POOLED:
这种数据源的实现利用“池”的概念将 JDBC 连接对象组织起来。
-
JNDI :
这个数据源实现是为了能在如 EJB 或应用服务器这类容器中使用,容器可以集中或在外部配置数据源,然后放置一个 JNDI 上下文的数据源引用
-
2、properties标签
实际开发中,习惯将数据源的配置信息单独抽取成一个properties文件,该标签可以加载额外配置的 properties:
jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql:///mybatis_db?useSSL=false&characterEncoding=UTF-8
jdbc.username=root
jdbc.password=root
修改 SqlMapConfig.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="jdbc.properties"></properties>
<!--环境配置-->
<environments default="mysql">
<!--使用mysql环境-->
<environment id="mysql">
<!--使用jdbc事务管理亲-->
<transactionManager type="JDBC"></transactionManager>
<!-- 使用连接池-->
<dataSource type="POOLED">
<property name="driver" value="${jdbc.driver}"/>
<property name="url" value="${jdbc.url}"/>
<property name="username" value="${jdbc.username}"/>
<property name="password" value="${jdbc.password}"/>
</dataSource>
</environment>
</environments>
<!--加载映射配置-->
<mappers>
<mapper resource="UserMapper.xml"></mapper>
</mappers>
</configuration>
测试结果:
关系示意图:
关于 typeAliases、mappers标签,可以参考文章:「Mybatis实战六」:Mybatis核心文件详解 - MyBatis常用配置typeAliases、mappers