后端分页应该注意的事项

分页前应该保证数据的有序性

在进行分页之前必须保证数据是有一定的顺序的,不能够随机
如果随机:

第一次请求第一页时,A数据可能被随机到第一页。当第二次请求时请求第二页,A数据在分页之前可能跑到第二页的数据的位置,此时再进行分页,就会发现本来在第一页出现过的数据A,又在第二页中重复出现。
很多朋友都会疑问,既然mysql中使用limit之前mysql已经默认排好序了,怎么会出现这个问题呢?
这时就要注意了,实现分页的方案并不是只有从mysql中使用limit呀。还有一种方法就是直接把全部数据查询出来,在service层中进行分页,所以刚刚这种场景就会出错。
如何在service层进行分页,可以看我的博客:https://blog.csdn.net/qq_56769991/article/details/125447487


在工作时,业务要求将查询出来的数据进行分页并随机排序,因为数据量较小,我是直接将全部数据查出来,在service中进行随机排序后,再进行的分页操作,这就造成了数据在第一页和第二页存在数据重复的情况。

所以在进行分页之前必须保证每个数据在一个确定的位置上,这样才会保证数据不会重复出现。

那随机排序怎么搞呢?
在进行分页的情况下,没有整体的乱序,只有局部乱序,即分页后,对当前页进行乱序操作。

结论:在进行分页操作之前:总体的数据的位置不能改变,否则会在不同页看到相同的数据(除了业务上在数据库插入新数据除外)

分页后应该保证当前页中的数据数量不变

分页后的数据,我们可以对分页后的当个数据项内容进行更改,但是千万不要添加新的数据项,否则可能造成"数据丢失"。比如我现在查询到10条数据,现在这边又将两个数据项添加到列表中,变成了12 ,但是前端只要你12条数据,你这被挤出去的2条数据就丢失了,下一页也不会出现你这两条数据。

结论:千万不要尝试在分页后添加新的数据项,否则会造成数据丢失(除非你有办法把将丢失的数据显示到前端

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值