Hobart-Ljw 2019-04-15 16:21 采纳率: 25%
浏览 1624
已结题

根据时间戳分页排序问题

我们现在有一张消息表 t_message,字段有 id(int),content(varchar),user_id(int),gtm_create(timestamp)。
我们这边是按照时间戳gmt_create来排序分页的.
语句如下:

第一页的sql:
select * from t_message order by gmt_create DESC limit 20;

第二页的sql:
select * from t_message where gmt_create<'第一页最后一条消息的时间戳' order by gmt_create DESC limit 20;

但是现在出现了一个问题,我们现在群发了40条消息,**时间戳都是相同的**

导致我们分页查询的时候第一页是正常的,直到第二页的时候其余20条数据就丢了。

我目前只能想到的办法就是对创建消息丢进消息队列里,一条一条的排队处理,这样有消息的时间戳就能保证不一样了!!

各位大佬还有什么好的解决办法呢??

  • 写回答

5条回答 默认 最新

  • Lei_Da_Gou 2019-04-15 16:28
    关注

    select * from t_message where gmt_create<='上一页最后一条消息的时间戳' order by gmt_create,id DESC limit 20;

    评论

报告相同问题?

悬赏问题

  • ¥40 复杂的限制性的商函数处理
  • ¥15 程序不包含适用于入口点的静态Main方法
  • ¥15 素材场景中光线烘焙后灯光失效
  • ¥15 请教一下各位,为什么我这个没有实现模拟点击
  • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
  • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置
  • ¥15 有没有研究水声通信方面的帮我改俩matlab代码