MyBatis - 03核心配置文件
(1)MyBatis核心配置文件层级关系
- configuration 配置
- properties 属性
- settings 设置
- typeAliases 类型别名
- typeHandlers 类型处理器
- objectFactory 对象工厂
- plugins 插件
- environments 环境
- environment 环境变量
- transactionManager 事务管理器
- dataSource 数据源
- environment 环境变量
- databaseIdProvider 数据库厂商标识
- mappers 映射器
(2)MyBatis 常用配置解析
(2.1)enviroments标签
数据库环境配置,支持多环境配置
<!--数据源环境--> <environments default="development"> // 指定默认的环境名称 <environment id="development"> // 指定当前环境名称 <transactionManager type="JDBC"></transactionManager> // 指定事务管理类型是JDBC <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>
> 事务管理器(transactionManager)类型有两种:
JDBC: 这个配置直接使用了jdbc的提交和回滚配置,依赖于从数据源得到的连接来管理事务作用域。
MANAGED: 这个配置几乎没做什么。它从来不提交或回滚一个连接,而是让容器来管理事务的整个生命周期(比如J2EE应用服务器上下文)。
默认情况下它会关闭连接,然而一些容器并不希望这样,因此需要将closeConnection属性设置为false来阻止默认的关闭行为。
> 数据源(dataSource)类型有三种:
UNPOOLED: 这个数据源的实现只是每次被请求时打开和关闭连接。
POOLED: 这个数据源的实现利用"池"的概念将jdbc连接对象组织起来。
JNDI: 这个数据源的实现是为了能在如EJB或应用服务器这类容器中使用。容器可以集中或在外部配置数据源,然后放置一个JNDI上下文的引用。
(2.2)mapper标签
该标签的作用是加载映射,加载方法有如下几种:
> 使用相对于类路径的资源引用,例如 <mapper resource="mapper/UserMapper.xml"/>
> 使用完全限定资源定位符(URL),例如 <mapper url="file:///var/mapper/UserMapper.xml"/>
> 使用映射器接口实现类的完全限定类名,例如 <mapper class="com.bearpx.dao.UserMapper"/>
> 将包内的映射器接口实现全部注册为映射器,例如 <package name="com.bearpx.dao"/>
<!--加载映射文件--> <mappers> <mapper resource="mapper/UserMapper.xml"></mapper> </mappers>
(2.3)Properties标签
将数据源的配置信息单独抽取成一个properties文件,该标签可以加载外部配置的properties文件
<!--通过properties标签加载外部properties文件--> <properties resource="jdbc.properties"></properties> <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>
(2.4)typeAliases标签
类型别名是为java类型设置一个短的名字。mybatis框架已经设置好的一些常用的类型的别名:
别名 <-> 数据类型 string <-> String 、long <-> Long 、int <-> Integer 、double <-> Double 、 boolean <-> Boolean
<!--自定义别名--> <typeAliases> <typeAlias type="com.bearpx.spring.mybatis.domain.User" alias="user"></typeAlias> </typeAliases>
<select id="findAll" resultType="user"> // resultType由 com.bearpx.spring.mybatis.domain.User 改成 user select * from user </select>