关键配置文件
- 全局配置文件
- Mapper配置文件
该 篇 主 要 介 绍 全 局 配 置 文 件 , 先 看 下 配 置 文 件 模 板 : \color{blue}{该篇主要介绍全局配置文件,先看下配置文件模板:} 该篇主要介绍全局配置文件,先看下配置文件模板:
<?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/>
<settings/>
<typeAliases/>
<typeHandlers/>
<objectFactory/>
<plugins/>
<environments/>
<databaseIdProvider/>
<mappers/>
</configuration>
接下来挨个介绍。
properties
该配置节点主要用来统一管理配置项的,配置后在整个文件中都可以使用,这样修改起来简单的多了,如下:
<properties resource="org/mybatis/example/config.properties">
<property name="username" value="dev_user"/>
<property name="password" value="F2Fa3!33TYyg"/>
</properties>
在配置文件中如何使用呢?
<dataSource type="POOLED">
<!--drive和url在上面并没有提供配置项,而是在resource="org/mybatis/example/config.properties"中指定-->
<property name="driver" value="${driver}"/>
<property name="url" value="${url}"/>
<!--这两个就是通过上面统一配置的-->
<property name="username" value="${username:root}"/>
<property name="password" value="${password}"/>
<!--如果username没有配置,则默认=root,但默认值特性需要手动开启,添加以下属性配置-->
<property name="org.apache.ibatis.parsing.PropertyParser.enable-default-value" value="true"/>
</dataSource>
除此之外还可以在SqlSessionFactoryBuilder.builder()
中传入参数,但并不建议这么做,那么这三个个加载顺序是什么?
优先级由下往上:3>2>1
- properties 内配置的property
- properties 的resource属性中加载的文件
- 代码参数传入的值
settings
该配置节是用来配置Mybatis全局环境的地方,影响很大,配置项也比较多,捡着几个重要的说明吧,其他的可以查看官网。
mapUnderscoreToCamelCase:false/true(官网介绍默认是false,实际在boot中已经设定为true)
作用:如果数据库字段命名带有下划线,配置是否自动转化为JAVA实体类属性的驼峰命名;当=true时,如字段命名user_name
,自动映射到JAVA实体类的userName
属性。
default-enum-type-handler
作用:当字段对应的实体类属性是枚举类型时,如StateEnum.normal(1,“正常”),其中数据库存储1
,返给前端是正常
,那么就需要使用该配置修改处理器:
configuration.default-enum-type-handler=org.apache.ibatis.type.EnumOrdinalTypeHandler
typeAliases
作用:简化编程,把繁琐的限定名去掉,如com.dony.hy.framework.admin.entity.SysUserPO
,简化为SysUser
:
<typeAliases>
<typeAlias alias="SysUser" type="com.dony.hy.framework.admin.entity.SysUserPO"/>
</typeAliases>
也可以直接指定包名,自动把指定包下所有的类都生成别名,其中别名默认使用类首字母小写形式表示,如:
<typeAliases>
<package name="com.dony.hy.framework.admin.entity"/>
</typeAliases>
sysUserPo就成了SysUserPO默认的别名,当然也可以在类上通过注解明确别名:
@Alias("SysUser")
public class SysUserPO{
...
}