不加锁解决幻读,数据库解决幻读的简单方法,拙见

在查询一批符合条件的数据时,如果其它操作新增了一些也符合条件的数据,翻页查询会导致第二页或者下一页出现上一页的重复数据。解决这种问题的一个方法就是给所有数据加上更新时间的字段,不管在添加数据还是修改数据,都去更新这个字段,然后在查询的时候判断更新时间的字段小于查询时间,这样就可以只查询在查询动作发生的时候之前的数据,如果是新增的数据,不会被查询到。如果要查新的记录,那就重新发起查询,通过新的查询时间去查所有记录。

新增的不会被查到,但是删除的情况下还是会出现数据漏查的情况,比如有其它操作删除了数据,查询下一页的时候就会跳过几条数据,导致有些数据没有展示出来。解决这个问题可以通过逻辑删除,也就是不删除真实数据,采用标记删除的方式,同时更新“更新时间”参数。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值