新聞中心
下面為您介紹SQL語句中GROUP BY 語句,GROUP BY 語句用于結(jié)合合計(jì)函數(shù),根據(jù)一個(gè)或多個(gè)列對(duì)結(jié)果集進(jìn)行分組。 希望對(duì)您學(xué)習(xí)SQL語句有所幫助。

公司主營業(yè)務(wù):網(wǎng)站設(shè)計(jì)、成都做網(wǎng)站、移動(dòng)網(wǎng)站開發(fā)等業(yè)務(wù)。幫助企業(yè)客戶真正實(shí)現(xiàn)互聯(lián)網(wǎng)宣傳,提高企業(yè)的競爭能力。創(chuàng)新互聯(lián)公司是一支青春激揚(yáng)、勤奮敬業(yè)、活力青春激揚(yáng)、勤奮敬業(yè)、活力澎湃、和諧高效的團(tuán)隊(duì)。公司秉承以“開放、自由、嚴(yán)謹(jǐn)、自律”為核心的企業(yè)文化,感謝他們對(duì)我們的高要求,感謝他們從不同領(lǐng)域給我們帶來的挑戰(zhàn),讓我們激情的團(tuán)隊(duì)有機(jī)會(huì)用頭腦與智慧不斷的給客戶帶來驚喜。創(chuàng)新互聯(lián)公司推出瑪曲免費(fèi)做網(wǎng)站回饋大家。
SQL GROUP BY 語法
SELECT column_name, aggregate_function(column_name)FROM table_nameWHERE column_name operator valueGROUP 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è)客戶的總金額(總訂單)。
我們想要使用 GROUP BY 語句對(duì)客戶進(jìn)行組合。
我們使用下列 SQL 語句:
SELECT Customer,SUM(OrderPrice) FROM OrdersGROUP BY Customer結(jié)果集類似這樣:
Customer SUM(OrderPrice)
Bush 2000
Carter 1700
Adams 2000
很棒吧,對(duì)不對(duì)?
讓我們看一下如果省略 GROUP BY 會(huì)出現(xiàn)什么情況:
SELECT Customer,SUM(OrderPrice) FROM Orders結(jié)果集類似這樣:
Customer SUM(OrderPrice)
Bush 5700
Carter 5700
Bush 5700
Bush 5700
Adams 5700
Carter 5700
上面的結(jié)果集不是我們需要的。
那么為什么不能使用上面這條 SELECT 語句呢?解釋如下:上面的 SELECT 語句指定了兩列(Customer 和 SUM(OrderPrice))。"SUM(OrderPrice)" 返回一個(gè)單獨(dú)的值("OrderPrice" 列的總計(jì)),而 "Customer" 返回 6 個(gè)值(每個(gè)值對(duì)應(yīng) "Orders" 表中的每一行)。因此,我們得不到正確的結(jié)果。不過,您已經(jīng)看到了,GROUP BY 語句解決了這個(gè)問題。
GROUP BY 一個(gè)以上的列
我們也可以對(duì)一個(gè)以上的列應(yīng)用 GROUP BY 語句,就像這樣:
SELECT Customer,OrderDate,SUM(OrderPrice) FROM OrdersGROUP BY Customer,OrderDate
【編輯推薦】
SQL Server日期計(jì)算語句
為您介紹一些不常見的SQL語句
SQL中CREATE INDEX語句的使用
一次插入多條記錄的SQL語句介紹
SQL中一次清空數(shù)據(jù)庫所有數(shù)據(jù)的語句寫法
本文標(biāo)題:詳解SQL中的GROUP BY語句
URL標(biāo)題:http://fisionsoft.com.cn/article/ccodpgg.html


咨詢
建站咨詢
