我們先來看一下這個代碼:
SELECT *
FROM product
WHERE SUM(slae_price) > 1000
GROUP BY product_type;
這樣子會報錯:
SELECT *
FROM product
WHERE SUM(slae_price) > 1000
GROUP BY product_type
> 1111 - Invalid use of group function
> 時間: 0.001s
為什么呢?
我們先來看一下這句查詢中的執行順序:FROM -> WHERE -> GROUP BY -> SELECT
首先我們知道像SUM()、AVG()、MAX()等等的聚合函數,是對結果進行篩選的,在FROM之后,我們只得到product這張表,如果對這張表進行聚合篩選后,那么接下來的GROUP BY該怎么辦呢?GROUP BY是對表進行分組的,但是你都已經WHERE篩選完了,還怎么分組,所以矛盾,所以不能在WHERE中使用聚合函數!
聚集函數也叫列函數,它們都是基於整列數據進行計算的,而where子句則是對數據行進行過濾的,在篩選過程中依賴“基於已經篩選完畢的數據得出的計算結果”是一種悖論,這是行不通的。更簡單地說,因為聚集函數要對全列數據時行計算,因而使用它的前提是:結果集已經確定!