在查询一批符合条件的数据时,如果其它操作新增了一些也符合条件的数据,翻页查询会导致第二页或者下一页出现上一页的重复数据。解决这种问题的一个方法就是给所有数据加上更新时间的字段,不管在添加数据还是修改数据,都去更新这个字段,然后在查询的时候判断更新时间的字段小于查询时间,这样就可以只查询在查询动作发生的时候之前的数据,如果是新增的数据,不会被查询到。如果要查新的记录,那就重新发起查询,通过新的查询时间去查所有记录。
新增的不会被查到,但是删除的情况下还是会出现数据漏查的情况,比如有其它操作删除了数据,查询下一页的时候就会跳过几条数据,导致有些数据没有展示出来。解决这个问题可以通过逻辑删除,也就是不删除真实数据,采用标记删除的方式,同时更新“更新时间”参数。