<?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>
<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:3306/mybatis?useSSL=true&useUnicode=true&characterEncoding=utf8"/>
<property name="username" value="root"/>
<property name="password" value="123456"/>
</dataSource>
</environment>
</environments>
<mappers>
<!--<mapper resource="com/liu/mapper/userMapper.xml"/>-->
<mapper class="com.liu.mapper.UserMapper2"/>
</mappers>
</configuration>
1.核心配置文件
configuration(配置)
properties(属性)
settings(设置)
typeAliases(类型别名)
typeHandlers(类型处理器)
objectFactory(对象工厂)
plugins(插件)
environments(环境配置)
environment(环境变量)
transactionManager(事务管理器)
dataSource(数据源)
databaseIdProvider(数据库厂商标识)
mappers(映射器)
<!-- 注意元素节点的顺序!顺序不对会报错 -->
注意元素节点的顺序!顺序不对会报错
2. 生命周期和作用域
SqlSessionFactoryBuilder 实例的最佳作用域是方法作用域(也就是局部方法变量)。
SqlSessionFactory 的最佳作用域是应用作用域。
3.MyBatis缓存
3.1简介
3.2 Mybatis缓存
mybatis默认有两个缓存,一级缓存和二级缓存。
一级缓存是默认开启的,sqlsession级别的本地缓存。
二级缓存需要手动开启。基于namespace级别的缓存。
3.3 一级缓存
一级缓存也叫本地缓存
与数据库一次会话,查询的结果会放在本地缓存当中去。
如果以后取相同的数据就会去缓存中拿,不会再去数据库中拿。
3.4 二级缓存
二级缓存又称为会话缓存,一级缓存的作用域太低了一次会话结束就清楚了。
二级缓存是namespace级别的缓存,一个名称空间,对应一个二级缓存;
我们开启了二级缓存之后,一次会话结束,就会将一级缓存的内容存到二级缓存当中去。
3.4.1开启全局缓存 【mybatis-config.xml】
<setting name="cacheEnabled" value="true"/>