【MyBatis】MyBatis缓存

Mybatis缓存

  1. Mybatis的一级缓存是指SqlSession。存储做用域是Session,会对同一个SQL语句进行Session缓存,来提升执行效率,一级缓存的做用域是一个SqlSession。Mybatis默认开启一级缓存。在同一个SqlSession中,执行相同的查询SQL,第一次会去查询数据库,并写到缓存中;第二次直接从缓存中取。当执行SQL时两次查询中间发生了增删改操做,则SqlSession的缓存清空。
  2. Mybatis的二级缓存是指mapper映射文件。二级缓存的做用域是同一个namespace下的mapper映射文件内容,多个SqlSession共享。Mybatis须要手动设置启动二级缓存。在同一个namespace下的mapper文件中,执行相同的查询SQL,第一次会去查询数据库,并写到缓存中;第二次直接从缓存中取。当执行SQL时两次查询中间发生了增删改操做,则二级缓存清空。
  3. 一级缓存区域是根据SqlSession为单位划分的。每次查询会先去缓存中找,若是找不到,再去数据库查询,而后把结果写到缓存中。Mybatis的内部缓存使用一个HashMap,key为hashcode+statementId+sql语句。Value为查询出来的结果集映射成的java对象。SqlSession执行insert、update、delete等操做commit后会清空该SQLSession缓存。
  4. 二级缓存是mapper级别的。Mybatis默认是没有开启二级缓存。

第一次调用mapper下的SQL去查询用户信息。查询到的信息会存到该mapper对应的二级缓存区域内。java

第二次调用相同namespace下的mapper映射文件中相同的SQL去查询用户信息。会去对应的二级缓存内取结果。sql

若是调用相同namespace下的mapper映射文件中的增删改SQL,并执行了commit操做。此时会清空该namespace下的二级缓存。数据库

相关文章
相关标签/搜索