app下拉刷新,SpringBoot后台如何保证每次请求的数据都是最新数据

最近有个问题,就是app下拉刷新请求数据,如何保证每次获取的数据都是最新的。
下拉刷新获取数据,后台一般都是分页返回通过创建时间来降序排序的数据,但是如果我新添加了一条数据,如何保证这条数据能够获取到,并且不和之前获取的数据产生冲突???
于是我采用时间戳作为mysql表的id主键,每次添加数据时,就可以保证每次后添加数据的id比先添加数据的id大
然后app每次请求的时候,带着两个参数,分别是page/firstPositionId,就是当前页数以及已经获取的数据集合的第一个的id
后端就可以通过判断新查询的数据要大于前端传入的id(时间戳)并通过创建时间降序排序,并返回相应的分页数据。
前端解析数据后,将返回的数据通过list.addAll(0,返回的数据),添加到集合的头部,便于下次请求刷新。
但是,如果一次添加的数量超过了当前请求分页的数量就会带来一个新的问题。
例如:一次分页查询10条数据,这次一下添加了20条数据。这次我们查询就只能查到前面10条(因为是分页查询)。但是后面10条数据就查询不到。
我想到了两个解决方法:
① 将后来插入的20条数据全部查询出来,解决方案就是:pageSize = Integer.MAX_VALUE; 将传入的pageSize变成Integer.MAX_VALUE,其他查询条件不变。(比较适合于并发量少)
只查询10条数据,然后在Android端,将之前的数据全部删掉,重新加载这10条数据。(比较适合于并发量大)

猜你喜欢

转载自blog.csdn.net/qq_46070108/article/details/121176656