Mybatis中的缓存
Mybatis中的缓存
什么是缓存
存在于内存中的临时数据。
为什么使用缓存
减少和数据库的交互次数,提高执行效率。
什么样的数据能使用缓存,什么样的数据不能使用
- 适用于缓存:
- 经常查询并且不经常改变的。
- 数据的正确与否对最终结果影响不大的。
- 不适用于缓存:
- 经常经常改变的数据。
- 数据的正确与否对最终结果影响很大的。
- 例如:商品的库存,银行的汇率,股市的牌价。
Mybatis中的一级缓存和二级缓存
- 一级缓存:
- 它指的是Mybatis中SqlSession对象的缓存。
- 当我们执行查询之后,查询的结果会同时存入到SqlSession为我们提供一块区域中。
- 该区域的结构是一个Map。当我们再次查询同样的数据,mybatis会先去sqlsession中,查询是否有,有的话直接拿出来用。
- 当SqlSession对象消失时,mybatis的一级缓存也就消失了。
- 二级缓存:
- 它指的是Mybatis中SqlSessionFactory对象的缓存。
- 由同一个SqlSessionFactory对象创建的SqlSession共享其缓存。
- 二级缓存的使用步骤:
- 让Mybatis框架支持二级缓存(在SqlMapConfig.xml中配置)
- 让当前的映射文件支持二级缓存(在IUserDao.xml中配置)
- 让当前的操作支持二级缓存(在select标签中配置)
缓存示例
`
/** * 测试一级缓存 */
@Test
public void TestAll()
{
User user = iUserDao.findById(42);
System.out.println(user);
User user1 = iUserDao.findById(42);
System.out.println(user1);
}
输出结果
com.itheima.domain.User@4d02f94e
com.itheima.domain.User@4d02f94e
/**
* 测试一级缓存
*/
@Test
public void TestAll()
{
User user = iUserDao.findById(42);
System.out.println(user);
sqlSession.close();
sqlSession= MyBaitsUtil.getSession();
iUserDao= sqlSession.getMapper(IUserDao.class);
User user1 = iUserDao.findById(42);
System.out.println(user1);
}
输出结果
com.itheima.domain.User@4d02f94e
com.itheima.domain.User@1e683a3e
/** * 测试二级缓存 */
全局配置
<settings><setting name="cacheEnabled" value="true"/></settings>
相应的xml配置
<cache/>
<!-- 查询所有 --><select id="findAll" resultType="user"
useCache="true"> select * from user u</select>
@Test
public void TestAll()
{
SqlSession sqlSession1 = MyBaitsUtil.getSession();
IUserDao dao1= sqlSession1.getMapper(IUserDao.class);
User user = dao1.findById(42);
System.out.println(user);
sqlSession1.close();//一级缓存消失
SqlSession sqlSession2 = MyBaitsUtil.getSession();
IUserDao dao2= sqlSession2.getMapper(IUserDao.class);
User user1 = dao2.findById(42);
System.out.println(user1);
}
输出结果
2019-07-17 10:27:28,023 612 [main] DEBUG ansaction.jdbc.JdbcTransaction - Setting autocommit to false on JDBC Connection [com.mysql.cj.jdbc.ConnectionImpl@55536d9e]
2019-07-17 10:27:28,029 618 [main] DEBUG .itheima.dao.IUserDao.findById - ==> Preparing: select * from user where id = ?
2019-07-17 10:27:28,085 674 [main] DEBUG .itheima.dao.IUserDao.findById - ==> Parameters: 42(Integer)
2019-07-17 10:27:28,120 709 [main] DEBUG .itheima.dao.IUserDao.findById - <== Total: 1
com.itheima.domain.User@fba92d3
2019-07-17 10:27:28,132 721 [main] DEBUG ansaction.jdbc.JdbcTransaction - Resetting autocommit to true on JDBC Connection [com.mysql.cj.jdbc.ConnectionImpl@55536d9e]
2019-07-17 10:27:28,132 721 [main] DEBUG ansaction.jdbc.JdbcTransaction - Closing JDBC Connection [com.mysql.cj.jdbc.ConnectionImpl@55536d9e]
2019-07-17 10:27:28,132 721 [main] DEBUG source.pooled.PooledDataSource - Returned connection 1431530910 to pool.
2019-07-17 10:27:28,136 725 [main] DEBUG com.itheima.dao.IUserDao - Cache Hit Ratio [com.itheima.dao.IUserDao]: 0.5
com.itheima.domain.User@2b91004a
`