关于Mybatis一级缓存的介绍 https://yq.aliyun.com/articles/18678 这篇已经介绍的非常详尽了。
但是读完以后我产生了一个疑问,如果在同一个session中2次相同的数据库操作之间,DB里的数据改变了,Mybatis一级缓存如何确保数据一致性,带着以上疑问我做了如下实验:
1.方法级别没有开启@Transactional,Mybatis查询记录如下
测试函数:
在以下函数第四行处会打一个端点,在断点期间,我会手工进行数据库操作
public String getTest() {
List<String> s=dao.getTest();
System.out.println(s.size());
List<String> s2=dao.getTest();
System.out.println(s2.size());
return "ok";
}
日志打印
第一次打印1,由于没有开启事物控制,所以session被关闭,第二次dao查询又重新开启了一次sqlsession,所以没有走一级缓存
2.方法级别开启了@Transactional,Mybatis查询记录如下
测试函数:
在以下函数第四行处会打一个端点,在断点期间,我会手工进行数据库操作
@Transactional
public String getTest() {
List<String> s=dao.getTest();
System.out.println(s.size());
List<String> s2=dao.getTest();
System.out.println(s2.size());
return "ok";
}
可见第二次Dao实际是从缓存中获得数据,所以拿到的数据量还是1行,即使我已经在库中插入了2条username='186251732**'的记录
结论:
Mybatis一级缓存在无事物的情况下确实提高了效率减轻了DB压力,但是在事物的里也会存在数据不一致的问题,必要时候需要采取一定的手段(数据库锁,线程锁)来保证数据一致性
原创文章,转载请声名出处 http://spjich.iteye.com/admin/blogs/2353479