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

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

檢索每個組中的最后一條記錄未獲得預期結果 - MySQL

檢索每個組中的最后一條記錄未獲得預期結果 - MySQL

PHP
鴻蒙傳說 2023-05-26 14:18:58
我想從表中獲取每個類別的最后兩個月的數據。表看起來像:Id 年月類別值1 2019 1 TEST1 102 2018 12 TEST1 10 3 201810 TEST1 104 2018 1 TEST2 105 2018 12 TEST2 106 2018 1 TEST3 10預期輸出:Id 年月類別值1 2019 1 TEST1 102 2018 12 TEST1 105 2018 12 TEST2 104 2018 1 TEST2 106 2018 1 TEST3 10我嘗試使用:SELECT a.year,a.month,a.value, a.categoryFROM test_data AS aWHERE (SELECT COUNT(*)FROM test_data AS bWHERE b.category = a.category AND (b.year >= a.year AND b.month >= a.month)) <= 2ORDER BY a.year DESC, a.month DESC但它給出了 TEST1 類別的額外記錄。我猜是因為它在年度條件下沒有按預期工作。請為此提供解決方案
查看完整描述

1 回答

?
侃侃無極

TA貢獻2051條經驗 獲得超10個贊

您的首要工作應該是修復您的數據模型并使用date類似 - 的數據類型來存儲日期信息,而不是將其分散在不同的列中。這應該像向表中添加新列并從現有列更新它一樣簡單:


alter table test_data add mydate date;

update test_data set mydate = concat(year, '-', month, '-01');

也就是說,要使您當前的查詢正常工作,您需要按如下方式微調日期條件。一種選擇使用算術:


SELECT a.year, a.month, a.value, a.category

FROM test_data AS a

WHERE (

    SELECT COUNT(*)

    FROM test_data AS b

    WHERE 

        b.category = a.category 

        AND 100 * b.year + b.month >= 100 * a.year + a.month

) <= 2

ORDER BY a.year DESC, a.month DESC

或者,如果您運行的是 MySQL 8.0,則可以使用row_number():


SELECT  a.year, a.month, a.value, a.category

FROM (

    SELECT 

        a.*,

        ROW_NUMBER() OVER(PARTITION BY a.category ORDER BY a.year DESC, a.month DESC)

    FROM test_data AS a 

) a

WHERE rn <= 2


查看完整回答
反對 回復 2023-05-26
  • 1 回答
  • 0 關注
  • 108 瀏覽

添加回答

舉報

0/150
提交
取消
微信客服

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

幫助反饋 APP下載

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

公眾號

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