第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

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

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

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

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

3 回答

?
眼眸繁星

TA貢獻1873條經(jīng)驗 獲得超9個贊

SELECT DISTINCT a,b,c FROM t

粗略相當(dāng)于:

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

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

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

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 )


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

TA貢獻2036條經(jīng)驗 獲得超8個贊

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

但是,這應(yīng)該有效(不需要聯(lián)接):

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

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


查看完整回答
反對 回復(fù) 2019-06-19
  • 3 回答
  • 0 關(guān)注
  • 543 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動學(xué)習(xí)伙伴

公眾號

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號