1. propertis属性
1) 需求:
将数据库连接参数配置在db.properties中,只需要在SqlMapConfig.xml中加载db.properties的属性值。在SqlMapConfig.xml中就不需要对数据库连接参数硬编码。
将数据库连接参数只配置在db.properties中,原因:方便对参数进行统一管理,其他xml可以引用该db.properties。
-
在config包下新建File:db.properties:
jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/mybatis?characterEncoding=utf-8
jdbc.username=root
jdbc.password=19940905
-
SqlMapConfig
<?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="db.properties"/>
<!--和spring整合后environment将被废除-->
<environments default="development">
<environment id="development">
<!-- 使用jdbc事务管理:mybatis管理-->
<transactionManager type="JDBC"/>
<!--数据库连接池:mybatis管理-->
<dataSource type="POOLED">
<!--原始配置方法
<property name="driver" value="com.mysql.jdbc.Driver"/>
<property name="url" value="jdbc:mysql://localhost:3306/mybatis?characterEncoding=utf-8"/>
<property name="username" value="root"/>
<property name="password" value="19940905"/>
-->
<!--使用db.propertis加载方法-->
<property name="driver" value="${jdbc.driver}"/>
<property name="url" value="${jdbc.url}"/>
<property name="username" value="${jdbc.username}"/>
<property name="password" value="${password}"/>
</dataSource>
</environment>
</environments>
<!--加载映射文件-->
<mappers>
<mapper resource="sqlmap/User.xml"/>
<mapper resource="mapper/UserMapper.xml"/>
</mappers>
</configuration>
2)properties特性:
注意:mybatis将按照如下顺序加载属性
- 在properties元素体内定义的属性首先被读取
- 然后读取properties元素中resource或url加载的属性,它会覆盖已读取的同名属性
- 最后读取parameterType传递的属性,它会覆盖已读取的同名属性
建议:
- 不要在properties元素体内添加任何属性,只将属性值定义在propertie文件中。在properties文件中定义属性名要有一定特殊性。如:jdbc.XXXX
2. settings全局参数配置
mybatis框架运行时可以调整一些运行参数。
比如:开启二级缓存,开启延时加载。
3. typeAliases(别名) 重点
- 单个别名定义
<!-- 别名定义-->
<typeAliases>
<!--针对单个别名定义 type:类型的路径 alias:别名-->
<typeAlias type="com.chinglee.mybatis.pojo.User" alias="user"/>
</typeAliases>
- 批量别名定义
<!-- 别名定义-->
<typeAliases>
<!--针对单个别名定义 type:类型的路径 alias:别名-->
<typeAlias type="com.chinglee.mybatis.pojo.User" alias="user"/>
<!-- 批量别名定义:指定包名,mybatis自动扫描包中的po类,自动定义别名
别名就是类明(首字母大写或小写都可以)
-->
<package name="com.chinglee.mybatis.pojo"/>
</typeAliases>
4.typeHandlers(类型处理器)
mybatis中通过typeHandlers完成jdbc类型和java类型的转换。
通常情况下,mybatis提供的类型处理器满足日常需要,不需要自定义。
5.mappers(映射配置)
- 通过resource加载单个映射文件
<!--加载映射文件-->
<mappers>
<mapper resource="sqlmap/User.xml"/>
<mapper resource="mapper/UserMapper.xml"/>
</mappers>
- 通过mapper接口加载
<!--通过mapper接口加载
遵循一些规范:需要将mapper接口类名和mapper.xml映射文件名称保持一致,且在一个目录中
前提:使用mapper代理的方法
-->
<mapper class="com.chinglee.mybatis.mapper.UserMapper"/>
- 批量加载mapper(推荐使用)
<!--批量加载mapper
指定mapper接口的包名,mybatis自动扫描包下面所有mapper接口进行加载
遵循一些规范:需要将mapper接口类名和mapper.xml映射文件名称保持一致,且在一个目录中
前提:使用mapper代理的方法
-->
<package name="com.chinglee.mybatis.mapper"/>