SQL GROUP BY 語(yǔ)句
合計(jì)函數(shù) (比如 SUM) 常常需要添加 GROUP BY 語(yǔ)句。
GROUP BY 語(yǔ)句
GROUP BY 語(yǔ)句用于結(jié)合合計(jì)函數(shù),根據(jù)一個(gè)或多個(gè)列對(duì)結(jié)果集進(jìn)行分組。
SQL GROUP BY 語(yǔ)法
SELECT column_name, aggregate_function(column_name) FROM table_name WHERE column_name operator value GROUP BY column_name
SQL GROUP BY 實(shí)例
我們擁有下面這個(gè) "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 |
現(xiàn)在,我們希望查找每個(gè)客戶(hù)的總金額(總訂單)。
我們想要使用 GROUP BY 語(yǔ)句對(duì)客戶(hù)進(jìn)行組合。
我們使用下列 SQL 語(yǔ)句:
SELECT Customer,SUM(OrderPrice) FROM Orders GROUP BY Customer
結(jié)果集類(lèi)似這樣:
Customer | SUM(OrderPrice) |
---|---|
Bush | 2000 |
Carter | 1700 |
Adams | 2000 |
很棒吧,對(duì)不對(duì)?
讓我們看一下如果省略 GROUP BY 會(huì)出現(xiàn)什么情況:
SELECT Customer,SUM(OrderPrice) FROM Orders
結(jié)果集類(lèi)似這樣:
Customer | SUM(OrderPrice) |
---|---|
Bush | 5700 |
Carter | 5700 |
Bush | 5700 |
Bush | 5700 |
Adams | 5700 |
Carter | 5700 |
上面的結(jié)果集不是我們需要的。
那么為什么不能使用上面這條 SELECT 語(yǔ)句呢?解釋如下:上面的 SELECT 語(yǔ)句指定了兩列(Customer 和 SUM(OrderPrice))。"SUM(OrderPrice)" 返回一個(gè)單獨(dú)的值("OrderPrice" 列的總計(jì)),而 "Customer" 返回 6 個(gè)值(每個(gè)值對(duì)應(yīng) "Orders" 表中的每一行)。因此,我們得不到正確的結(jié)果。不過(guò),您已經(jīng)看到了,GROUP BY 語(yǔ)句解決了這個(gè)問(wèn)題。
GROUP BY 一個(gè)以上的列
我們也可以對(duì)一個(gè)以上的列應(yīng)用 GROUP BY 語(yǔ)句,就像這樣:
SELECT Customer,OrderDate,SUM(OrderPrice) FROM Orders GROUP BY Customer,OrderDate