Mybatis延迟加载和立即加载

作者: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);
}

你可能感兴趣的:(Mybatis)