Mybaits一级缓存和二级缓存分别是什么,区别是什么?

缓存是什么: 
        缓存(cache),数据交换的缓冲区,当应用程序需要读取数据时,先从数据库中将数据取出,放置在缓冲区中,应用程序从缓冲区读取数据。  
        通俗讲缓存就是要将一些经常使用的数据缓存到内存或者各种储存介质中,当再次使用时可以不用去数据库中查询,减少与数据库的交互,提高性能。

哪些数据会放到缓存:
       通常情况下,会将那些变化较少且经常用到的数据会放到缓存中,比如新闻等等;另外将用户保存到缓存也是一种很好的策略,这样登录的时候就可以极速响应了;
哪些情况下不适合放入缓存:
      经常改变的数据,或者数据的正确与否对最终结果影响很大的。比如商品的库存,股市等等。由于缓存的缺点,得到的数据可能不是最新的,当商品的库存无法实时更新,不仅会对商家造成损失,也会加大与消费者的纠纷;股市数据一旦不是最新的,股民会遭受很大损失。

       

Mybatis 的缓存分为两类,分别是一级缓存和二级缓存。

一级缓存
一级缓存是默认开启的,它在一个sqlSession会话里面的所有查询操作都会保存到缓存中,一般来说一个请求中的所有增删改查操作都是在同一个sqlSession里面的,所以我们可以认为每个请求都有自己的一级缓存,如果同一个sqlSession会话中2 个查询中间有一个 insert 、update或delete 语句,那么之前查询的所有缓存都会清空;

一级缓存工作流程:
 1.将查询的数据缓存在内存中
 2.再次查询时先在缓存空间找看是否由对应的数据
 3.如果有,直接使用缓存空间的数据,不用去数据库查询
 4.如果没有,则去数据库查找相对应数据
 5.将在数据库查到的数据存到缓存空间
 6.将查询结果返回
 7.判断缓存级别是否为STAEMENT级别,如果是的话,清空本地缓存

一级缓存失效的情况:
 1.同一个sqlsession两次查询期间执行了任何一次增,删,改,提交事务等方法时就会清空一级缓存
 2.不同sqlsession对应不同的一级缓存
 3.同一个sqlsession但查询条件不同
 4. 同一个sqlsession两次查询期间手动清除了一级缓存 (sqlSession.clearCache())

二级缓存
二级缓存是全局的,多个请求可以共用一个缓存,二级缓存需要手动开启,有两种方式配置二级缓存,
缓存会先放在一级缓存中,当sqlSession会话提交或者关闭时才会将一级缓存刷新到二级缓存中,开启二级缓存后,用户查询时,会先去二级缓存中找,找不到在去一级缓存中找。

你可能感兴趣的:(JavaEE,缓存,java,mybatis)