gpt4 book ai didi

深入理解Mybatis一级缓存

转载 作者:qq735679552 更新时间:2022-09-29 22:32:09 24 4
gpt4 key购买 nike

CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.

这篇CFSDN的博客文章深入理解Mybatis一级缓存由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.

客户端向数据库服务器发送同样的sql查询语句,如果每次都去访问数据库,会导致性能的降低.

那么怎么提高呢?

mybatis为我们提供了一级缓存的策略 。

在一个sqlSession开启和关闭之间,sqlSession对象内部(其实是Executor)会维护一个缓存的对象,当查询数据时候,先从缓存中寻找是否存在该条数据,存在就直接取出来,不存在,向数据库发送sql查询, 然后将查询后的数据存入缓存,和返回给程序.

这样会存在一个问题:

如果在第一次和第二次查询期间,有程序更改了要查讯的数据库的数据,就会引起读取的数据是错误的,也就是 。

脏读,其实是mybatis在sqlSession执行commit()方法后会清空这个缓存。第二次去查询,依然会从数据库中查询. 。

也可以手动调用sqlSession的clearCache()方法清除缓存 。

小例子:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
@Test
   public void testCacheLever1() throws Exception{
     SqlSession session = factory.openSession();
     UserMapper mapper = session.getMapper(UserMapper. class );
     //第一次请求,查询id为1的用户
     User user = mapper.findUserById( 1 );
     System.out.println(user);
     //更改数据,会清空缓存
     user.setUsername( "yyyy" );
     mapper.updateUser(user);
     session.commit();
     //第二次查询会从缓存中找
     User user2 = mapper.findUserById( 1 );
     System.out.println(user2);
     session.close();
   }

问题:

如果sqlSession关闭了,缓存也就清空了。这怎么使用缓存来提高效率呢?

好了,下篇文章给大家介绍mybatis二级缓存.

以上所述是小编给大家介绍的Mybatis一级缓存,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对我网站的支持! 。

原文链接:http://blog.csdn.net/i_jack/article/details/53764496 。

最后此篇关于深入理解Mybatis一级缓存的文章就讲到这里了,如果你想了解更多关于深入理解Mybatis一级缓存的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com