hibernate缓存,mybatis缓存详解

先说hibernate的缓存吧:

        hibernate的缓存有一级缓存,二级缓存,查询缓存。一级缓存 很简单,session级别的缓存,通过get,update可以将对象放到一级缓存中。二级缓存 sessionFactory级别的缓存,通过get,list可以将对象放到二级缓存中,这里我必须细讲一下,list虽然能够把对象放入二级缓存,但是我们不能通过list中去获取二级缓存,必须配合查询缓存使用,那他是怎么与查询缓存配合使用的呢,首先我们知道查询缓存是数据缓存,那么我们知道list方法如果查询的是对象,只能将每个对象的id放到查询缓存中去,但是对象放到二级缓存中去了,那么我们通过list查询对象,首先会获得所有数据的id,然后通过id去查询对象,但是在这时,我们的对象已经在二级缓存中了,所以他会从二级缓存中取得对象,并不会从数据库中查询。二级缓存还有个知识点,因为二级缓存是sessionfactory级别的缓存,个人认为也可以理解为进程级别的缓存,那么我们对缓存中的数据进行更新是否会更新二级缓存中的数据勒,答案是会更新的,在做更新操作时,会先清空二级缓存中对应的数据。
    查询缓存是数据缓存,上面提到的都是对象缓存,这一点一定要区分开来,那么它的生命周期是当有数据改变的时候,那么它的生命周期就结束了,通过这一点我们可以看出当我们插入向数据库插入一条数据时,查询缓存中的数据就会清空,因此list查询数据并不会导致查询数据出现查询结果与预期不同的现象。同时我们在使用缓存时,需要防范脏读,为什么呢,因为当我们用其它手段(hibernate除外)对数据库进行操作,那么hibernate是检测不到的,导致缓存中的数据时脏数据。
    hibernate的优点 :
        1、完全的面向对象编程    
        2、hibernate的缓存很牛的,一级缓存,二级缓存,查询缓存   重点    
        3、编程的时候就比较简单了    
        4、跨平台性很强    
        5、使用场合就是企业内部的系统
    hibernate的缺点    
        1、效率比较低    
        2、表中的数据如果在千万级别,则hibernate不适合    
        3、如果表与表之间的关系特别复杂,则hibernate也不适合

下面开始介绍mybatis缓存:

mybatis缓存有一级缓存,二级缓存、Mybatis默认提供一级缓存,缓存范围是一个sqlSession。
二级缓存:缓存范围是跨SqlSession的,范围是mapper的namespace,相同的namespace使用一个二级缓存结构。需要进行参数配置让mybatis支持二级缓存。

猜你喜欢

转载自blog.csdn.net/weixin_41888013/article/details/83543707