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

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

如何(或可以)在多列上選擇DISTISTION?

如何(或可以)在多列上選擇DISTISTION?

森林海 2019-06-19 17:10:56
如何(或可以)在多列上選擇DISTISTION?我需要從一個表中檢索所有行,其中兩個列的合并都是不同的。因此,我希望所有的銷售,沒有任何其他銷售發生在同一天,以相同的價格。基于日和價格的獨特銷售將被更新到活動狀態。所以我在想:UPDATE salesSET status = 'ACTIVE'WHERE id IN (SELECT DISTINCT (saleprice, saledate), id, count(id)              FROM sales             HAVING count = 1)但我的大腦會痛得更厲害。
查看完整描述

3 回答

?
眼眸繁星

TA貢獻1873條經驗 獲得超9個贊

SELECT DISTINCT a,b,c FROM t

粗略相當于:

SELECT a,b,c FROM t GROUP BY a,b,c

通過語法習慣這個組是個好主意,因為它更強大。

對于您的查詢,我會這樣做:

UPDATE salesSET status='ACTIVE'WHERE id IN(
    SELECT id    FROM sales S    INNER JOIN
    (
        SELECT saleprice, saledate        FROM sales        GROUP BY saleprice, saledate        HAVING COUNT(*) = 1 
    ) T    ON S.saleprice=T.saleprice AND s.saledate=T.saledate )


查看完整回答
反對 回復 2019-06-19
?
慕桂英3389331

TA貢獻2036條經驗 獲得超8個贊

查詢的問題是,當使用GROUP BY子句(本質上是使用DISTION)時,您只能使用按組分組的列或聚合函數。不能使用列id,因為可能存在不同的值。在您的例子中,由于HAVING子句,總是只有一個值,但是大多數RDBMS不夠聰明,無法識別它。

但是,這應該有效(不需要聯接):

UPDATE salesSET status='ACTIVE'WHERE id IN (
  SELECT MIN(id) FROM sales  GROUP BY saleprice, saledate  HAVING COUNT(id) = 1)

您也可以使用MAX或AVG代替MIN,只有在只有一個匹配行的情況下才能使用返回列值的函數。


查看完整回答
反對 回復 2019-06-19
  • 3 回答
  • 0 關注
  • 545 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

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

幫助反饋 APP下載

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

公眾號

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