mybatis提供查询缓存,用于减轻数据库压力,提高数据库性能
mybatis提供一级缓存和二级缓存
一级缓存时sqlsession级别的缓存,在操作数据库时需要构造sqlsession对象,在对象中有一个数据结构(hashmap)用于存储缓存数据,不同的sqlsession之间缓存数据区域互不影响,叫一级缓存
二级缓存是mapper级别的缓存,多个sqlsession去操作同一个mappser的sql语句,多个sqlsesion可以共同二级缓存
如果缓存中有数据,就不用从数据库中获取,大大提高系统性能
一级缓存
第一次发起查询用户id为1的信息,先查找缓存中是否有id为1的用户信息,如果没有,从数据库中查询信息,得到用户信息,将用户信息存储到一级缓存中
如果sqlsession去执行commit操作,将清空sqlsession中的一级缓存,为了让缓存中永远存储最新信息,避免脏读
第二次发起查询用户id为1的信息,先去找缓存中是否有id为1的用户信息,如果有,直接从缓存中获取用户信息
mybatis默认支持一级缓存,不需要在配置文件中配置