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

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

為什么使用GROUP BY,不能用rownum?求解釋?

為什么使用GROUP BY,不能用rownum?求解釋?

慕神8447489 2021-08-25 19:15:03
員工編號 日期1 日期2000100 2010-6-7 2010-6-1 09:05:00000100 2010-6-6 2010-6-1 11:05:00000100 2010-6-6 2010-6-1 11:10:00現在想取最后一條,大家幫幫忙啊。
查看完整描述

2 回答

?
qq_笑_17

TA貢獻1818條經驗 獲得超7個贊

SELECT *
FROM tab t1
WHERE 員工編號||T0_CHAR日期1)|| T0_CHAR(日期2)
IN (SELECT 員工編號||T0_CHAR(日期1)|| T0_CHAR(MAX(日期2))
FROM tab
WHERE 員工編號 = t1.員工編號
AND 日期1 = t1.日期1
GROUP BY 員工編號, 日期1)

看你這個應該是ORACLE,是取得日期最小的對應的時間最大記錄吧,如果這樣的話,可以這樣寫

找出日期最小的記錄。...
SELECT 員工編號, 日期1, 日期2 FROM TAB t1
WHERE NOT EXISTS (SELECT 1 FROM tab
WHERE t1.員工編號 = 員工編號 AND t1.日期1 > 日期1

然后按照日期2降序排列,取得第一行值,為什么不可以用ROWNUM呢?用這個快很多哦。。
如果不用rownum就要這樣整了。。。
SELECT 員工編號, 日期1, 日期2
from ((SELECT 員工編號, 日期1, 日期2 ROW_NUMBER() OVER(ORDER BY 日期2 DESC) rk
FROM (SELECT 員工編號, 日期1, 日期2
FROM TAB t1
WHERE NOT EXISTS (SELECT 1 FROM tab
WHERE t1.員工編號 = 員工編號 AND t1.日期1 > 日期1) t
WHERE rk = 1 ) t2



查看完整回答
反對 回復 2021-08-30
?
慕勒3428872

TA貢獻1848條經驗 獲得超6個贊

SELECT * FROM TB T WHERE 日期2=(SELECT MAX(日期2) FROM TB WHERE 員工編號=T.員工編號)

查看完整回答
反對 回復 2021-08-30
  • 2 回答
  • 0 關注
  • 543 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

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

幫助反饋 APP下載

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

公眾號

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