作者:rookiequ
自己学习参考所有,如有错误,请大佬们留言指正,谢谢!
Mybatis延迟加载和立即加载
什么是延迟加载?
真正在使用数据的时候才发起查询,不用的时候不查询,按需加载(懒加载)
什么是立即加载?
不管用不用,一调用方法,马上发起查询
-
针对一对多和多对多:通常情况下使用延迟加载
-
针对多对一和一对一:通常情况下使用立即加载
Mybatis中的缓存
- 适用缓存的数据:经常被查询,不经常改变的数据,数据的正确性对结果的影响不大
- 不适用缓存的数据:经常改变的数据,敏感的数据
@Test
public void cache01Test(){
//这里研究的mybatis的缓存问题
//不清楚缓存的话,第一次查询后,如果立马改变数据之后,在进行相同的查询,会直接从刚刚的sql缓存中获取数据,而不能获取最新的数据
User user1 = userDAO.findUserById(50);
User user2 = userDAO.findUserById(50);
//这里比较的是user1和user2的地址值 结果为true
System.out.println(user1==user2);
}
@Test
public void cache02Test(){
//这里研究的mybatis的缓存问题
User user1 = userDAO.findUserById(50);
//清空缓存
sqlSession.clearCache();
User user2 = userDAO.findUserById(50);
//这里比较的是user1和user2的地址值 false
System.out.println(user1==user2);
}