MyBatis的缓存机制作用:
- web系统性能瓶颈----IO(磁盘io,网络IO)
- 减少web应用和数据库(磁盘)访问次数,减轻数据库访问压力,数据尽可能缓存(内存)获取,提高查询效率
一级缓存:SqlSession,在一个事务内部有效 (基本上没有什么用)
二级缓存:SqlSessionFactory级别,全局缓存
① 全局缓存根据namespace来划分缓存空间。
② 执行了增删改操作,清空当前sql所对应的namespace的缓存。
机制:
web应用执行sql获取数据,mybatis会先从缓存中获取,如果没有,则发送sql查询数据库,返回结果,同时将结果放入缓存中。
底层:(Mybatis缓存原码)
Map<String,Object> map = new HashMap<String,Object>();//内置缓存。
map.put(“绑定了参数执行的sql”,查询结果返回值);//存储
MyBatis内置缓存实现:是用一个Map实现的,key是真正执行的sql语句,value是缓存的结果。
MyBatis集成ehcache: