一道題搞懂數據庫中Having的用法

先說結論:

WHERE 搜索條件在進行分組操作之前應用;而 HAVING 搜索條件在進行分組操作之後應用。

HAVING 語法與 WHERE 語法類似,但 HAVING 可以包含聚合函數。

什麼意思?

我們擁有下面這個 "Orders" 表:

O_Id OrderDate OrderPrice Customer
1 2008/12/29 1000 Bush
2 2008/11/23 1600 Carter
3 2008/10/05 700 Bush
4 2008/09/28 300 Bush
5 2008/08/06 2000 Adams
6 2008/07/21 100 Carter

現在,我們希望查找訂單總金額少於 2000 的客戶。

我們使用如下 SQL 語句:

SELECT Customer,SUM(OrderPrice) FROM Orders
GROUP BY Customer
HAVING SUM(OrderPrice)<2000

結果集類似:

Customer SUM(OrderPrice)
Carter 1700

現在我們希望查找客戶 "Bush" 或 "Adams" 擁有超過 1500 的訂單總金額。

我們在 SQL 語句中增加了一個普通的 WHERE 子句:

SELECT Customer,SUM(OrderPrice) FROM Orders
WHERE Customer='Bush' OR Customer='Adams'
GROUP BY Customer
HAVING SUM(OrderPrice)>1500

發現沒有?上面這個Having和Sum 聯合使用了,上面這句換成where就不行,因爲where不能喝聚合函數聯合使用。

結果集:

Customer SUM(OrderPrice)
Bush 2000
Adams 2000

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章