您当前的位置: 首页 >  缓存

止步前行

暂无认证

  • 4浏览

    0关注

    247博文

    0收益

  • 0浏览

    0点赞

    0打赏

    0留言

私信
关注
热门博文

Mybatis的缓存介绍

止步前行 发布时间:2018-06-29 10:24:06 ,浏览量:4

一、一级缓存

1、一级缓存(本地缓存):

1)、一级缓存是基于sqlSession级别的缓存,在Mybatis中,一级缓存是一直开启的;

2)、一级缓存会创建一个sqlSession级别的一个Map,在与数据库同一次会话期间,将查询到的数据放在本地缓存中。

3)、在同一次会话期间,如果以后需要获取相同的数据,直接从缓存中拿,没必要再去查询数据库;

2、一级缓存失效情况:

1)、sqlSession不同,即不是同一次会话,每一次都会执行一遍Sql语句;

2)、sqlSession相同,查询条件不同;(当前一级缓存中还没有这个数据)

3)、sqlSession相同,两次查询之间执行了增删改操作;(在mysql中,每一次增删改操作都是清除一级缓存)

4)、sqlSession相同,手动清除了一级缓存(缓存清空),调用sqlSession.clearCache()方法;
二、二级缓存

二级缓存(全局缓存): 1、基于namespace级别的缓存,一个namespace对应一个二级缓存; 2、工作机制: (1)、一个会话,查询一条数据,这个数据就会被放在当前会话的一级缓存中; (2)、如果会话关闭,一级缓存中的数据会被保存到二级缓存中,新的会话查询信息,就可以参照二级缓存中的内容; (3)、不同namespace查出的数据会放在自己对应的缓存中(也就是各自的Map中)

sqlSession--->EmployeeMapper--->Employee
 		DepartmentMapper--->Department

(4)、效果:查出的数据都会被默认先放在一级缓存中,只有会话提交或者关闭以后,一级缓存中的数据才会转移到二级缓存中; (5)、使用:

1)、在Mybatis的配置文件中,开启全局二级缓存配置:
		
		
2)、去mapper.xml中配置使用二级缓存:

3)、此时的POJO需要实现序列化接口

(6)、和缓存有关的设置/属性:

1)、cacheEnabled=true:开启缓存
	cacheEnabled=false:关闭缓存(二级缓存关闭)(一级缓存一直可用的)
2)、每个select标签都有useCache="true",如果设置为false,则表示不使用缓存,
		每次执行查询操作,都会去查数据库,但一级缓存依然使用,二级缓存不会使用;
3)、每个增删改标签都会默认有:flushCache="true"属性,即每次执行增删改操作,
		都会默认清空缓存,(一级二级都会清除)
4)、sqlSession.clearCache();只是清除当前sqlSession的一级缓存;
5)、localCacheScope:本地缓存作用域:(一级缓存SESSION);
		当前会话的所有数据保存在会话缓存中;STATEMENT:可以禁用一级缓存;		
三、整合第三方缓存

第三方缓存整合:

1)、导入第三方缓存包即可;
2)、导入与第三方缓存整合的适配包;
3)、在Mybatis设置文件中,设置开启缓存;
4)、在每个mapper.xml中的namespace标签下使用自定义缓存

参考Mybatis整合Ecache的官方文档,so easy~~~~ http://www.mybatis.org/ehcache-cache/

关注
打赏
1657848381
查看更多评论
立即登录/注册

微信扫码登录

0.1456s