一、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 configurationPUBLIC "-//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