记一次分页数据重复

庞大的数据量,前端展示往往会选择分页。但是在分页获取数据的时候,有新的数据插入,就会存在重复的问题。

 

 案发现场,祖传代码MongDB,获取视频是分页获取的。分析下原因,比如每次获取10条数据,按上传时间倒序排列。

那么第一次获取的数据是 10,9,8,7,6,5,4,3,2,1

在这个时间段有人上传了数据12,11

那么在第二次分页获取数据的时候,倒序排列12,11,10,9,8,7,6,5,4,3,2,1,0,-1,-2,-3,-4,-5,-6 这样 2,1 数据就重复了

解决思路,第一次分页index =0的时候,存一个time,便于理解这里存一个id。第一次分页查询后存储 10,以后每次分页增加一个查询条件 id < 10。

//这里用的redisson
RBucket<Object> bucket = redissonClient.getBucket(userId+"requestTime"); Object o = bucket.get() == null? 0 : bucket.get(); long requestTime = pageIndex == 0 ? 0 : Long.valueOf(String.valueOf(o));//第一次请求数据,取返回数据的第一条存入redis
...
if(pageIndex == 0){
bucket.set(data.get(0).getTime());
}
 

 

posted @ 2021-06-10 17:22  别动我的猫  阅读(2987)  评论(0编辑  收藏  举报