大事务提交后,查询数据不可见问题

    @Transactional(rollbackFor = Exception.class)
    @Override
    public void vehiclePortrait() {
        log.info("车辆画像统计开始");
        List<OverloadVehicleInfo> overloadVehicleInfos = vehicleInfoDao.findAll();
        if (CollectionUtils.isNotEmpty(overloadVehicleInfos)) {
            overloadVehicleInfoCacheDao.deleteAll();
            List<OverloadVehicleInfoCache> overloadVehicleInfoCaches = Lists.newArrayList();
            for (OverloadVehicleInfo overloadVehicleInfo : overloadVehicleInfos) {
                OverloadVehicleInfoCache overloadVehicleInfoCache = new OverloadVehicleInfoCache();
                BeanMapper.copy(overloadVehicleInfo, overloadVehicleInfoCache);
                overloadVehicleInfoCaches.add(overloadVehicleInfoCache);
            }
            List<List<OverloadVehicleInfoCache>> lists = ListUtil.partition(overloadVehicleInfoCaches, listSize);
            log.info("车辆画像统计共执行:{}次", lists.size());
            int i = 0;
            for (List<OverloadVehicleInfoCache> overloadVehicleInfoCacheList : lists) {
                log.info("车辆画像统计第{}次", ++i);
                overloadVehicleInfoCacheDao.saveAll(overloadVehicleInfoCacheList);
//                long count = overloadVehicleInfoCacheDao.count();
//                System.out.println("count: " + count);
            }
        }
        log.info("车辆画像统计结束");
    }

此方法执行结束后(共写入38000多条数据),两分钟后才查询出数据。原因是:

当一个事务提交时:

  1. **重做日志(Redo Log)**会被立即或按配置策略写入磁盘,确保事务的改动可以被恢复。
  2. 数据页可能还在内存的缓冲池(如InnoDB的Buffer Pool)中,并不一定立即刷盘。数据库系统会根据各种策略(如Checkpoint机制)决定何时将缓冲池中的脏页(已修改但未写回磁盘的页面)写入磁盘。
    也就是说,事务提交成功后,只代表数据已经写入到了Redo Log,但还未写入到磁盘中,这中间有两分钟的时间差。
  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值