SQL中WHERE子句中為什么不能使用聚合函數?


我們先來看一下這個代碼:

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子句則是對數據行進行過濾的,在篩選過程中依賴“基於已經篩選完畢的數據得出的計算結果”是一種悖論,這是行不通的。更簡單地說,因為聚集函數要對全列數據時行計算,因而使用它的前提是:結果集已經確定!


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM