亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

MySQL的“分組依據”和“排序依據”

MySQL的“分組依據”和“排序依據”

慕碼人2483693 2019-10-08 14:47:01
我希望能夠從電子郵件表中選擇一堆行并按發件人分組。我的查詢如下所示:SELECT     `timestamp`, `fromEmail`, `subject`FROM `incomingEmails` GROUP BY LOWER(`fromEmail`) ORDER BY `timestamp` DESC該查詢幾乎可以按我希望的方式工作-它選擇按電子郵件分組的記錄。問題在于主題和時間戳記與特定電子郵件地址的最新記錄不符。例如,它可能返回:fromEmail: [email protected], subject: hellofromEmail: [email protected], subject: welcome當數據庫中的記錄是:fromEmail: [email protected], subject: hellofromEmail: [email protected], subject: programming questionfromEmail: [email protected], subject: welcome如果“編程問題”主題是最新的,那么在對電子郵件進行分組時如何使MySQL選擇該記錄?
查看完整描述

4 回答

?
慕雪6442864

TA貢獻1812條經驗 獲得超5個贊

在ORDER BY之后通過用GROUP BY包裹查詢來進行GROUP BY,如下所示:


SELECT t.* FROM (SELECT * FROM table ORDER BY time DESC) t GROUP BY t.from


查看完整回答
反對 回復 2019-10-08
?
白衣非少年

TA貢獻1155條經驗 獲得超0個贊

正如答復中已經指出的那樣,當前答案是錯誤的,因為GROUP BY從窗口中任意選擇記錄。


如果使用MySQL 5.6或MySQL 5.7和ONLY_FULL_GROUP_BY,則正確的(確定性)查詢為:


SELECT incomingEmails.*

  FROM (

    SELECT fromEmail, MAX(timestamp) `timestamp`

    FROM incomingEmails

    GROUP BY fromEmail

  ) filtered_incomingEmails

  JOIN incomingEmails USING (fromEmail, timestamp)

GROUP BY fromEmail, timestamp

為了使查詢有效運行,需要正確的索引編制。


請注意,為簡化起見,我刪除了LOWER(),在大多數情況下不會使用。


查看完整回答
反對 回復 2019-10-08
  • 4 回答
  • 0 關注
  • 638 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號