记一次分页数据重复


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

 

 案发现场,祖传代码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());
}
 

 


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM