对于Mybatis,最核心的全局配置文件就是SqlMapConfig.xml(mybatis-config.xml),其中不仅包含了数据库连接信息,同时还包含了Mapper映射文件的加载路径、全局参数以及类别别名等一系列MyBatis的核心配置信息。

mybatis-config.xml 可以改为其他名字

一、配置文件的构成

mybatis配置文件 mysql mybatis配置文件怎么写_mybatis

(并非每一项都需要配置,在spirngboot项目里,不做任何配置也是可以的,因为有默认的配置):

MyBatis中的配置,不但有类型限制,还有顺序限制。

必须按照:<properties>、<settings>、<typeAliases>、<typeHandlers>、…顺序排放。

常用的setting配置

mybatis配置文件 mysql mybatis配置文件怎么写_mybatis配置文件 mysql_02

1. <!– 配置全局性 cache 的 ( 开 / 关) default:true –>
<setting name=“cacheEnabled” value=“true”/>

2. <!– 是否使用 懒加载 关联对象 同 hibernate中的延迟加载 一样 default:true –>
<setting name=“lazyLoadingEnabled” value=“true”/>

3. <!– [当对象使用延迟加载时 属性的加载取决于能被引用到的那些延迟属性,否则,按需加载(需要的是时候才去加载)] –>
<setting name=“aggressiveLazyLoading” value=“true”/>

4. <!– 是否允许单条sql 返回多个数据集 (取决于驱动的兼容性) default:true –>
<setting name=“multipleResultSetsEnabled” value=“true”/>

5. <!– 是否可以使用列的别名 (取决于驱动的兼容性) default:true–>
<setting name=“useColumnLabel” value=“true”/>

6. <!–允许JDBC 生成主键。需要驱动器支持。如果设为了true,这个设置将强制使用被生成的主键,有一些驱动器不兼容 不过仍然可以执行。default:false–>
<setting name=“useGeneratedKeys” value=“false”/>

7. <!–指定 MyBatis 如何自动映射 数据基表的列 NONE:不隐射 PARTIAL:部分 FULL:全部–>
<setting name=“autoMappingBehavior” value=“PARTIAL”/>

8. <!– 这是默认的执行类型
SIMPLE :简单
REUSE:执行器可能重复使用prepared statements 语句
BATCH:执行器可以重复执行语句和批量更新
–>
<setting name=“defaultExecutorType” value=“SIMPLE”/>

9. <!– 设置驱动等待数据响应的超时数 默认没有设置–>
<setting name=“defaultStatementTimeout” value=“25000″/>

10. <!– [是否启用 行内嵌套语句 defaut:false] –>
<setting name=“safeRowBoundsEnabled” value=“false”/>

11. <!– [是否 启用 数据中 A_column 自动映射 到 Java类中驼峰命名的属性 default:fasle] –>
<setting name=“mapUnderscoreToCamelCase” value=“false”/>

12. <!– 设置本地缓存范围 session:就会有数据的共享 statement:语句范围 (这样就不会有数据的共享 ) defalut:session –>
<setting name=“localCacheScope” value=“SESSION”/>

13. <!– 设置但JDBC类型为空时,某些驱动程序 要指定值,default:OTHER –>
<setting name=“jdbcTypeForNull” value=“DEFAULT”/>

14. <!– 设置触发延迟加载的方法 –>
<setting name=“lazyLoadTriggerMethods” value=“equals,clone,hashCode,toString”/>

引入外部配置文件
配置文件:db.properties

mybatis配置文件 mysql mybatis配置文件怎么写_配置文件_03

 通过properties标签引入配置文件:

mybatis配置文件 mysql mybatis配置文件怎么写_配置文件_04

配置文件的两种写法
一种是通过外置的properties文件 (优先级更高!!!)
一种是直接在“<properties>”标签里添加属性
 

mybatis配置文件 mysql mybatis配置文件怎么写_mysql_05

类型别名 typeAliases

可用简短名,代替较长的名称,降低冗余。

两种设置方法
方法1:

mybatis配置文件 mysql mybatis配置文件怎么写_mybatis_06

方法2:

mybatis配置文件 mysql mybatis配置文件怎么写_java_07

映射器 mappers

mybatis配置文件 mysql mybatis配置文件怎么写_mybatis配置文件 mysql_08

mybatis配置文件 mysql mybatis配置文件怎么写_mybatis_09

mybatis配置文件 mysql mybatis配置文件怎么写_mybatis_10

配置文件加载流程(源码)

mybatis配置文件 mysql mybatis配置文件怎么写_mysql_11