求问 Mybatis 的缓存

2022-01-01 19:39:39 +08:00
 daimubai

已经将一级缓存设置为了 statement ,关闭了二级缓存

mybatis:
  configuration:
    cache-enabled: false
    local-cache-scope: statement

测试

    @GetMapping("/test")
    @Transactional
    public User test() throws InterruptedException {
        User user = userMapper.selectById(1);
        System.out.println(user);
        TimeUnit.SECONDS.sleep(5);
        User user2 = userMapper.selectById(1);
        System.out.println(user2);
        return user2;
    }

疑问

2022-01-01 19:33:18.320 DEBUG 49182 --- [nio-8000-exec-4] com.ding.mapper.UserMapper.selectById    : ==>  Preparing: SELECT * FROM `user` WHERE id = ? 
2022-01-01 19:33:18.321 DEBUG 49182 --- [nio-8000-exec-4] com.ding.mapper.UserMapper.selectById    : ==> Parameters: 1(Integer)
2022-01-01 19:33:18.322 DEBUG 49182 --- [nio-8000-exec-4] com.ding.mapper.UserMapper.selectById    : <==      Total: 1
User(id=1, username=test, password=222, phone=)
2022-01-01 19:33:23.327 DEBUG 49182 --- [nio-8000-exec-4] com.ding.mapper.UserMapper.selectById    : ==>  Preparing: SELECT * FROM `user` WHERE id = ? 
2022-01-01 19:33:23.327 DEBUG 49182 --- [nio-8000-exec-4] com.ding.mapper.UserMapper.selectById    : ==> Parameters: 1(Integer)
2022-01-01 19:33:23.328 DEBUG 49182 --- [nio-8000-exec-4] com.ding.mapper.UserMapper.selectById    : <==      Total: 0
User(id=1, username=test, password=222, phone=)

日志是打印了两遍 sql ,在休眠的 5 秒前我已经在数据库把这条数据清空了,但是第二次执行的结果返回的还是和第一次一样

1786 次点击
所在节点    Java
5 条回复
daimubai
2022-01-01 19:41:30 +08:00
这应该不是 Mybatis 缓存作的怪吧,如果缓存生效的话第二个 sql 应该不会执行才对。

但是我把事务去掉就可以了,如果非要加事务呢,求大佬指点
az467
2022-01-01 19:44:50 +08:00
db 隔离级别改为 read committed
daimubai
2022-01-01 19:48:10 +08:00
@az467

show variables like 'transaction%'

READ-COMMITTED

大佬,是读已提交的
daimubai
2022-01-01 20:19:50 +08:00
@az467 ok 了,问题最后定位到了 Spring 的隔离级别没有使用数据库的,和缓存无关。多谢
potatowish
2022-01-02 09:57:12 +08:00
一级缓存是 sqlsession 级别的缓存,每次操作数据库会构造不同的 sqlsession 对象,缓存互不影响。

开启事务后,同一个事务中的数据库访问会复用 sqlsession ,所以会使用同一个缓存

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://tanronggui.xyz/t/825687

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX