<?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简介
1.什么是缓存
存在内存中的临时数据。
将用户经常查询的数据放在缓存(内存)中,用户去查询数据就不用从磁盘上(关系型数据库数据文件)查询,从缓存中查询,从而提高查询效率,解决了高并发系统的性能问题。
2.为什么使用缓存?
减少和数据库的交互次数,减少系统开销,提高系统效率。
3.什么样的数据能使用缓存?
经常查询并且不经常改变的数据。
3.2 Mybatis缓存
mybatis默认有两个缓存,一级缓存和二级缓存。
一级缓存是默认开启的,sqlsession级别的本地缓存。
二级缓存需要手动开启。基于namespace级别的缓存。
3.3 一级缓存
一级缓存也叫本地缓存
与数据库一次会话,查询的结果会放在本地缓存当中去。
如果以后取相同的数据就会去缓存中拿,不会再去数据库中拿。
一级缓存失效的四种情况
1.不同的sqlsession之间缓存不同。
2.两次查询中新增了增删改的操作
3.当前缓存中,不存在这个数据
4.手动清楚缓存
3.4 二级缓存
二级缓存又称为会话缓存,一级缓存的作用域太低了一次会话结束就清楚了。
二级缓存是namespace级别的缓存,一个名称空间,对应一个二级缓存;
我们开启了二级缓存之后,一次会话结束,就会将一级缓存的内容存到二级缓存当中去。
3.4.1开启全局缓存 【mybatis-config.xml】
<setting name="cacheEnabled" value="true"/>
只要开启了二级缓存,我们在同一个Mapper中的查询,可以在二级缓存中拿到数据
查出的数据都会被默认先放在一级缓存中
只有会话提交或者关闭以后,一级缓存中的数据才会转到二级缓存中