天天看點

一道題搞懂資料庫中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