Postgresql收件箱查询

Postgresql收件箱查询,第1张

概述我有一个如下所示的Messages表: Messages+-----+------------+-------------+--------------+| id | sender_id | receiver_id | created_at |+-----------------------------------------------+| 1 | 1 | 我有一个如下所示的Messages表:
Messages+-----+------------+-------------+--------------+|  ID |  sender_ID | receiver_ID |  created_at  |+-----------------------------------------------+|  1  |      1     |      2      |   1/1/2013   ||  2  |      1     |      2      |   1/1/2013   ||  3  |      2     |      1      |   1/2/2013   ||  4  |      3     |      2      |   1/2/2013   ||  5  |      3     |      2      |   1/3/2013   ||  6  |      5     |      4      |   1/4/2013   |+-----------------------------------------------+

如果’thread’是给定sender_ID和receiver_ID之间的一组消息,我希望查询返回最近10个线程的最新10条消息,其中sender_ID或receiver_ID是给定的ID.

给定user_ID为5的预期输出:

+-----+------------+-------------+--------------+|  ID |  sender_ID | receiver_ID |  created_at  |+-----------------------------------------------+|  1  |      5     |      2      |   1/4/2013   ||  2  |      5     |      2      |   1/4/2013   ||  3  |      2     |      5      |   1/4/2013   ||  4  |      3     |      5      |   1/4/2013   ||  5  |      5     |      2      |   1/3/2013   ||  6  |      5     |      4      |   1/3/2013   |+-----------------------------------------------+

例如,用户5和2之间(上面有4个)和10个线程的限制(上面有3个)之间的最多10个消息的限制.

我一直在使用子查询尝试这种查询,但没有设法获得不同线程数量的第二个限制.

SELECT * FROM (SELECT disTINCT ON (sender_ID,receiver_ID) messages.* FROM messages WHERE (receiver_ID = 5 OR sender_ID = 5) ORDER BY sender_ID,receiver_ID,created_at DESC)   q ORDER BY created_at DESC liMIT 10 OFFSET 0;

我正在考虑创建一个新的Thread表,其中包含一个thread_ID字段,该字段将是sender_ID receiver_ID的串联,然后只是加入Messages,但我有一种偷偷摸摸的怀疑,它只能用一个表来实现.

我没有对此进行测试,但看起来您忘记了子查询中的liMIT 10,它为您提供了10个最近的线程:
SELECT  *FROM  (SELECT disTINCT ON     (sender_ID,receiver_ID) messages.*    FROM     messages    WHERE     (receiver_ID = 5 OR sender_ID = 5)   ORDER BY     sender_ID,created_at DESC   liMIT     10)     qORDER BY  created_at DESC liMIT  10OFFSET  0;

(我已经很好地打印了sql,因此更容易分辨出发生了什么.)

总结

以上是内存溢出为你收集整理的Postgresql收件箱查询全部内容,希望文章能够帮你解决Postgresql收件箱查询所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/sjk/1181348.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-02
下一篇 2022-06-02

发表评论

登录后才能评论

评论列表(0条)

保存