SqlMapConfig文件简要
SqlMapConfig.xml为MyBatis框架核心配置文件,
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>
<!--配置别名
typeAliases和environments是平等级别的标签
type是实体类的完整类名
alias是类的别名
-->
<typeAliases>
<typeAlias type="com.soft.domain.User" alias="User"/>
<typeAlias type="com.soft.domain.DeptEntity" alias="DeptEntity"/>
<typeAlias type="com.soft.domain.EmpEntity" alias="EmpEntity"/>
</typeAliases>
<environments default="development">
<environment id="development">
<transactionManager type="JDBC" />
<dataSource type="POOLED">
<property name="driver" value="com.mysql.jdbc.Driver" />
<property name="url" value="jdbc:mysql://localhost/he" />
<property name="username" value="root" />
<property name="password" value="root" />
</dataSource>
</environment>
</environments>
<mappers>
<!-- 映射文件的位置 -->
<mapper resource="com/soft/domain/User.xml" />
</mappers>
</configuration>
1、properties属性
需求:
1、将数据库连接参数单独配置在db.peoperties中,只需要在SqlMapConfig.xml中加载db.peoperties的属性值
SqlMapConfig.xml中就不需要对数据库配置参数硬编码
2、将数据库连接参数只配置在db.peoperties中,原因:方便对参数进行统一管理,其他XML文件也可以引用
<!--加载属性文件-->
<properties resource="db.properties">
<!--配置属性名、属性值-->
<property name="" value=""/>
</properties>
**注意:**mybatis加载属性的顺序
1)在properties元素体内定义的属性首先被读取
2)然后会读取properties元素中resource或url加载的属性,它会覆盖已读取的同名属性
3)最后读取parameterType传递的属性,会覆盖已读取的同名属性
因此,通过parameterType传递的属性具有最高优先级,resource或url加载的属性次之,最低优先级的是properties元素体内定义的属性
建议:
不在properties元素体内添加任何属性,只将属性值定义在properties文件中。
在properties文件中定义属性名要有一定的特殊性,如:XXX.XXX.XXX
2、settings全局参数配置
mybatis框架在运行时可以调整一些运行参数,比如:开启二级缓存,开启延迟加载
全局参数将会影响mybatis的运行行为
3、typeAliases(别名),重点
需求:
1、在mapper.xml中,定义很多的statement,statement需要parameterType指定输入参数的类型,需要resultType指定输出结果的映射类型。
2、如果在指定类型时输入类型全路径,不方便进行开发,可以针对parameterType或resultType指定的类型定义别名,在mapper.xml中通过别名定义,方便开发
- mybatis中支持默认别名
- mybatis支持自定义别名
<!--别名定义-->
<typeAliases>
<!--针对单个别名定义: type:类型全路径 alias:别名-->
<typeAlias type="User全路径" alias="user"/>
<!--针对批量别名定义:指定包名,mybatis自动扫描包中的po类,自动定义别名,别名就是类名(首字母大写或小写都可以)-->
<package name="包名"/>
</typeAliases>
4、typeHandlers(类型处理器)
mybatis中通过typeHandlers完成jdbc类型和Java类型的转换
通常情况下,mybatis提供的类型处理器满足日常需要,不需要自定义类型处理器
5、objectFactory(对象工厂)
6、plugins(插件)
7、environments(环境集合属性对象)
environment(环境子属性对象)
transactionManager(事务管理)
dataSource(数据源)
注:5,6,7不常用,读者自行了解
8、mappers(映射配置)
<!--加载映射文件-->
<mappers>
<!--通过resource方法加载单个映射文件,使用相对于类路径的资源-->
<mapper resource="映射文件路径/映射文件名称(含扩展名)">
<!--通过url加载单个映射文件,使用完全限定路径-->
<mapper url="file:///D:User.xml"/>
<!--通过mapper接口加载:需要遵循一定规范,需要将mapper接口类名和mapper.xml映射文件名称保持一致,且在同一目录(前提使用mapper代理方法)-->
<!--(将mapper.java和mapper.xml放在同一目录,且同名)-->
<mapper class=""/>
<!--批量加载mapper(推荐使用)-->
<!--指定mapper接口的包名,mybatis自动扫描包下边所有mapper接口进行加载-->
<!--遵循一些规范:需要将mapper接口类名和mapper.xml映射文件名称保持一致,且在同一目录(前提使用mapper代理方法)-->
<package name="mapper接口的包名"/>
</mappers>