MyBatis cache失效

现象描述:

在Mapper.xml里面启用了全局缓存<cache/>

用户提交了更新操作,业务操作为status=2.

但页面查询的表状态还是status=1.查找数据库发现status=2

也就是MyBatis的缓存读到之前的status=1的未提交数据,但数据库确实已经改为status=2

分析原因:

页面有个操作,在Ajax的POST提交的同时。就开始重定向到页面查询页面。导致页面viewMatch读到之前状态为1的数据。

$.post("/ss/goMatch", {id: ${item.id!''}},

     function(data){

        layer.msg(data.msg);

        layer.close(index);

}, "json");

window.open("/ss/viewMatch/${item.id}");

解决方法:

调整打开viewMatch的位置,让Ajax执行完成后再跳转。运行后恢复正常。

$.post("/ss/goMatch", {id: ${item.id!''}},

      function(data){

         layer.msg(data.msg);

         layer.close(index);

window.open("/ss/viewMatch/${item.id}");

 }, "json");

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值