天天看點

SQL GROUP BY 語句

合計函數 (比如 sum) 常常需要添加 group by 語句。

group by 語句用于結合合計函數,根據一個或多個列對結果集進行分組。

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

o_id

orderdate

orderprice

customer

1

2008/12/29

1000

bush

2

2008/11/23

1600

carter

3

2008/10/05

700

4

2008/09/28

300

5

2008/08/06

2000

adams

6

2008/07/21

100

現在,我們希望查找每個客戶的總金額(總訂單)。

我們想要使用 group by 語句對客戶進行組合。

我們使用下列 sql 語句:

結果集類似這樣:

sum(orderprice)

1700

很棒吧,對不對?

讓我們看一下如果省略 group by 會出現什麼情況:

5700

上面的結果集不是我們需要的。

那麼為什麼不能使用上面這條 select 語句呢?解釋如下:上面的 select 語句指定了兩列(customer 和 sum(orderprice))。"sum(orderprice)" 傳回一個單獨的值("orderprice" 列的總計),而 "customer" 傳回 6 個值(每個值對應 "orders" 表中的每一行)。是以,我們得不到正确的結果。不過,您已經看到了,group by 語句解決了這個問題。

我們也可以對一個以上的列應用 group by 語句,就像這樣:

 group by 語句常見錯誤:

2、