Mybatis缓存
1.什么是缓存?
- 存在内存中的临时数据
2.为什么使用缓存?
- 减少和数据库交互次数,提高性能
3.适用于缓存的数据:
- 经常查询并且不经常改变的
- 数据的正确与否对最终结果影响不大
4.不是适用于缓存的数据:
- 经常改变的数据,数据的正确与否对最终结果影响很大的。例如:商品的库存,银行的汇率,股市的牌价。
一级缓存
-
一级缓存:指的是mybatis中sqlsession对象的缓存。
默认已经开启一级缓存。
-
当我们执行查询之后,查询的结果会同时存入sqlsession为我们提供一块区域中,该结果是一个map,当我们再次查询同样的数据,mybatis会先去sqlsession中查询是否有,有的话直接拿出来。当sqlsession对象消失,mybatis的一级缓存就消失了。
方案:调用两次同样的查询,比价查询结果的地址值,肯定相同,然后第一次查询完关闭sqlsession,在一次查询,比较地址值,肯定是不同的
-
当我调用sqlsession的修改,添加,删除,就会清空SqlSession中的一级缓存,目的是为了让缓存中存储的是最新的信息,避免脏读。
二级缓存
- 二级缓存:指的是mybatis中SqlSessionFactory对象的缓存。由同一个SqlSessionFactory对象创建的SqlSession共享缓存。
-
二级缓存的使用步骤:(配置文件)
- 让mybatis框架支持二级缓存(SqlMapConfig.xml中配置)
- 让当前的映射文件支持二级缓存(IUserDao.xml中配置)开启二级缓存
- 让当前的操作支持二级缓存(在select标签中配置) usercache=true
2.1 开启二级缓存后,查询出来的结果是两次不同的对象
原因:因为二级缓存中的内存是数据,而不是对象,谁用会创建一个新的对象,只是把数据填充进去
-
SpringBoot整合Mybatis-通用mapper使用二级缓存:(注解)
- 在yml文件中:
- 在Mapper接口上使用@CacheNamespace注解:
- 数据库entity需要序列化:
延迟加载
1.mybatis 是否支持延迟加载?延迟加载的原理是什么?
-
Mybatis仅支持association关联对象和collection关联集合对象的延迟加载,association指的就是一对一,collection指的就是一对多查询。在Mybatis配置文件中,可以配置是否启用延迟加载lazyLoadingEnabled=true|false。
-
它的原理是,使用CGLIB创建目标对象的代理对象,当调用目标方法时,进入拦截器方法,比如调用a.getB().getName(),拦截器invoke()方法发现a.getB()是null值,那么就会单独发送事先保存好的查询关联B对象的sql,把B查询上来,然后调用a.setB(b),于是a的对象b属性就有值了,接着完成a.getB().getName()方法的调用。这就是延迟加载的基本原理。
当然了,不光是Mybatis,几乎所有的包括Hibernate,支持延迟加载的原理都是一样的。
2什么是延迟加载?
在真正使用数据时候才发起查询,不用的时候不去查询,(按需要加载,也叫懒加载)
关系表中:一般是 一对多 ,多对对
3什么是立即加载
不管用不用,只要一调用方法,马上发起查询
关系表中:一般是 一对一 ,多对一
4 Mybatis是否支持延迟加载?如果支持,它的实现原理是什么?
只支持一对一,一对多
Mybatis仅支持association关联对象和collection关联集合对象的延迟加载,association指的就是一对一,collection指的就是一对多查询。在Mybatis配置文件中,可以配置是否启用延迟加载lazyLoadingEnabled=true|false