Mybatis的缓存介绍

一、一级缓存

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的配置文件中,开启全局二级缓存配置:
                <setting name="cacheEnabled" value="true"/>
        2)、去mapper.xml中配置使用二级缓存:<cache></cache>
        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标签下使用自定义缓存
<cache type="org.mybatis.caches.ehcache.EhcacheCache"></cache>

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

猜你喜欢

转载自blog.csdn.net/zxd1435513775/article/details/80852742