聊天页面分页加载逻辑

第一页:

1.从数据库按时间倒序取出数据,

假设数据为(为表示方便,仅仅显示时间):

15:26

14:26

13:26


2.再倒序加入list,此时list中的数据为

13:26

14:26

15:26


3.该list添加之前的list成为新的list

第一页,之前的list为空的,所以操作后新的list的数据为:

13:26

14:26

15:26


第二页:

1.从数据库按时间倒序取出数据,

假设数据为(为表示方便,仅仅显示时间):

12:26

11:26

10:26

2.再倒序加入list,此时list中的数据为

10:26

11:26

12:26

3.该list添加之前的list成为新的list

10:26

11:26

12:26

13:26

14:26

15:26


抽象成算法如下:

//listAll 用来记录之前的list

ArrayList<E> listAll = new ArrayList<E>();

//获得list

List<E> list=getMsgByPage(pageCount,offset);

//反转

Collections.reverse(list);

//加入之前的list

list.addAll(listAll );

//当前的list赋值给listall

listall=list;




分页加载的sql:


假设一页加载三个,则第一页为:
select * from immsg  where  text="3423" order by dialogId limit 3 offset 0;

第二页为:
select * from immsg  where  text="3423" order by dialogId limit 3 offset 3;

第三页为:
select * from immsg  where  text="3423" order by dialogId limit 3 offset 6;

抽象出来为:

int pagecount=3;//每页的数量

int page;//第几页

select * from immsg  where  text="3423" order by dialogId limit pagecount  offset (page-1)*pagecount  ;



  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值