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收件箱查询所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)