- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个复杂的查询在 sql fiddle 中不起作用.
在我工作的应用程序中,我们将用户 Gmail 与我们的数据库同步。我们将电子邮件存储在电子邮件表中,我们还有一个回复表,我们在其中存储引用 header ,其中列出了电子邮件的所有父回复。
例如,如果我有这样一封电子邮件:
id | subject | message_id
---------------------------------------------------------------------------------------------
1 | howzitgoin | 53856b1448c89_23fa9605badd015951@3a139e8c-0b81-42c2-8e59-133c262e96a9.mail
replys表中不会有记录:
现在,如果我们像这样导入此电子邮件的回复:
id | subject | message_id
---------------------------------------------------------------------------------------------
2 | RE: howzitgoin | CAEBV8YTu_A6LtP_uGuQ-QSVj3zojWUiwcjGZpsPPEz1Pj3_i1A@mail.gmail.com
我们将在回复表中存储以下内容:
email_id | message_id
------------------------------------------------------------------------------------------
2 | 53856b1448c89_23fa9605badd015951@3a139e8c-0b81-42c2-8e59-133c262e96a9.mail
如果我们收到回复:
id | subject | message_id
---------------------------------------------------------------------------------------------
3 | RE: howzitgoin | 53856b88a2a09_23fa9605badd01601b@3a139e8c-0b81-42c2-8e59-133c262e96a9.mail
我们将在回复表中存储以下内容:
email_id | message_id
---------------------------------------------------------------------------------------------
3 | 53856b1448c89_23fa9605badd015951@3a139e8c-0b81-42c2-8e59-133c262e96a9.mail
3 | CAEBV8YTu_A6LtP_uGuQ-QSVj3zojWUiwcjGZpsPPEz1Pj3_i1A@mail.gmail.com
经过一番摸索,我想到了这个问题:
WITH "ranked_replies" AS
(
SELECT "r"."email_id", "r"."message_id", "rnk"
FROM (SELECT *, rank() OVER (PARTITION BY "message_id" ORDER BY "email_id" DESC) AS "rnk" FROM "replies") AS "r"
INNER JOIN "emails"
ON ("emails"."message_id" = "r"."message_id")
),
"count_of_replies" AS
(
SELECT "email_id", count(*) AS "count", count(*) AS "thread_count"
FROM "ranked_replies"
GROUP BY "email_id"
)
SELECT DISTINCT "emails".*, "thread_count"
FROM "emails"
LEFT JOIN "count_of_replies"
ON ("emails"."id" = "count_of_replies"."email_id")
WHERE
(
("folder" = 'INBOX')
AND
(
("emails"."message_id" NOT IN (SELECT "message_id" FROM "ranked_replies" WHERE ("rnk" != 1)))
OR ("emails"."message_id" IS NULL)
)
AND ("emails"."id" NOT IN (SELECT "email_id" FROM "ranked_replies" WHERE ("rnk" != 1)))
)
ORDER BY "created_at" DESC LIMIT 50 OFFSET 0
问题是它没有返回主题为“不返回”的电子邮件线程。
之所以会这样,是因为where子句的这一部分:
("emails"."message_id" NOT IN (SELECT "message_id" FROM "ranked_replies" WHERE ("rnk" != 1))
这排除了主题为“不返回”的根电子邮件,因为它在排名为 1 和 2 的 ranked_replies 中有 2 行。
我想要一个查询:
引用 SQLFiddle 示例:它应该返回电子邮件:#5(线程 1 的最高排名)、#8(线程 2 的最高排名)、#9(不在线程中)和#10(非最高排名) ,但收件箱中只有一个线程)
我在使用 #10 时遇到了问题。
最佳答案
“未返回”的邮件没有返回,因为顶部的有回复,而底部的不在“收件箱”中。
作为旁节点:由于您将其作为“应用程序”,我想您可以通过将所有(至少直到特定数量)邮件的元数据传输到客户端并在那里进行排序/过滤来增强它。这很可能比让数据库根据用户群等进行所有思考更好地扩展(并且在用户体验方面更快)。回到你的问题:
我很不确定你为什么要为此使用 rank()
,所以我放弃了它。如果你因为我忽略的其他要求而想继续使用它,你可以这样做:在“回复”的子选择上使用排名,它只处理回复在当前文件夹中的行。
也许您想在我的解决方案中跳过“threadid”的选择,并通过首先插入这个 id 来解决这个问题。或者您自己为每个线程创建一个唯一的 ID。
由于我不知道 gmail 显示邮件的方式,我假设您需要以下内容:
我创建了 this SQL Fiddle那样做。在那里我还更改了数据库模型以引用由其主键 (id) 而不是其 message_id 回复的消息。因为这是一个数字序列,所以它可以用来寻址线程树,我也这样做了。
这是解决方案:
WITH "thread" AS
( -- select the uppermost id per thread
SELECT r."email_id", min("reply_to_id") AS "threadid"
FROM "replies" r
INNER JOIN "emails" e ON r.email_id = e.id
-- create tree only for current folder
AND e.folder = 'INBOX'
GROUP BY r."email_id"
),
"lastmail" AS
( -- select the highest email per thread
SELECT t."threadid", max(r."email_id") AS "lastmail"
FROM replies r
INNER JOIN thread t ON t.threadid = r.reply_to_id
GROUP BY t."threadid"
),
"count_of_replies" AS
(SELECT r."email_id", count(r.*) AS "thread_count"
FROM replies r
INNER JOIN thread t ON t.threadid = r.reply_to_id
GROUP BY r."email_id")
SELECT DISTINCT "emails".*, "thread_count"
FROM "emails"
LEFT JOIN "count_of_replies"
ON ("emails"."id" = "count_of_replies"."email_id")
WHERE
(
-- only from current folder
("folder" = 'INBOX') AND
(
-- the ones that are in no thread
("emails"."id" NOT IN (SELECT "email_id" FROM "thread"
UNION ALL
SELECT "threadid" from "thread"))
OR
-- the ones that are top in their thread
("emails"."id" IN (SELECT "lastmail" FROM "lastmail"))
)
)
ORDER BY "created_at" DESC LIMIT 50 OFFSET 0
关于postgresql - 用于返回电子邮件对话列表的复杂查询,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24281864/
在电子邮件中 Received: header 可以合法地多次出现,并且具有互斥的值... Received: three.example.com Received: two.example.co
是否有任何代码/宏可以合并到我的 sas 程序中,一旦我的 sas 代码在运行时发生错误,它会立即给我发送电子邮件? 另外,这封电子邮件是否可能包含发生的错误? 最佳答案 是的……也不是…… 这是可能
我有一个包含三个 td 的表格,每个表格都需要包含图像。 td 的宽度和高度是固定的,但图像大小可以变化。目标是在不扭曲单元格或图像本身的情况下拟合图像。不能使用 background-image 属
首先非常感谢大家过去提出的宝贵建议,我们正在创建一个应用程序,在某些事件中想要将电子邮件/短信发送到我们已经尝试过 openURL 调用的指定电话号码,但它会打开现有的内置iPhone 的电子邮件/短
我正在使用 apache commons mail 发送电子邮件。不幸的是,我遇到了以下异常: org.apache.commons.mail.EmailException: Sending the
我可以在我的 ~/.hgrc 文件中设置我常用的电子邮件地址,但是有没有办法为一个 hg 项目指定我想被称为不同的名称/电子邮件(类似到项目目录中的 git 的 .git/config 文件覆盖 ~/
$message = 'New user registration\n\n There is a new submission on the site and below are the detail
使用 outlook 我可以发送在邮件正文中插入图像的电子邮件(不是作为附件)。我如何使用 PHP 中的 mail() 函数来做到这一点? 最佳答案 我会推荐 Swift Mailer: http:/
以下代码的目标是将所选图表粘贴到我的文本下方的电子邮件正文中。但是,它继续将其粘贴在我的文本上方。我该如何更改它以使其粘贴在下面?谢谢! Set OutApp = CreateObject("Outl
首先,我知道不建议使用正则表达式发送电子邮件,但我必须对此进行测试。 我有这个正则表达式: \b[A-Z0-9._%-]+@[A-Z0-9.-]+\.[A-Z]{2,4}\b 在 Java 中,我这样
如何在没有任何第三方程序的情况下从 Python 发送电子邮件? 最佳答案 使用Python email和 smtplib模块。示例:http://docs.python.org/library/em
我目前正在使用此代码在 html 表中显示 mysql 记录 "; . . echo ' '. $row["Email1"] . ' '; . . echo ""; }
在电子邮件中使用 HTML 时,是否可以仅将链接的一部分着色为特定颜色? 我试过: red part of link normal part ...我知道如果我拆分链接是可能的,但我正在努力将它们保持
我正在处理一封 html 电子邮件,我有一个非常简单的元素 (ul),我想将它移到页面下方。 我检查了campaign monitor's guide并且不支持负边距,或者 position: abs
我使用表格创建了我的 HTML 电子邮件,该表格有一个背景图像,在大多数基于 Web 的电子邮件客户端中都能正常显示。 我正在努力让背景图片显示在 Outlook 中。 我最近的尝试,我尝试了以下操作
我对 PHP/CSS 和一般编程还很陌生。 我想改变文本区域中文本的格式,就像在这里所做的那样,例如,当为突出显示的文本添加标签“代码示例”时,它会缩进它,或者当将它设置为粗体时,它会加粗它。 这样做
嘿,你能推荐我哪些 C++ 库或类可用于在 C++ 中通过 SMTP 发送电子邮件。我在 Windows 平台上。我需要一个支持附件和 SSL 连接的库。有哪些可用选项。我不打算实现我自己的 :) 问
想知道是否可以在 HTML 电子邮件中包含一个表单。我要做的就是将图像输入提交到 Paypal 购买页面。我希望它直接进入 Paypal ,而无需先进入营销页面... 我会拥有 paypal 要求的完
我负责“ reshape ”我们的 IT 部门通信。我想用纯 HTML/CSS 来发送我们的电子邮件通知,以确保它的可移植性。 下面是代码,它在 Outlook 中看起来完全符合我的要求,但是一旦将内
我正在学习编写响应式电子邮件模板。目前我有:https://jsfiddle.net/q12yg2z6/
我是一名优秀的程序员,十分优秀!