Ⅰ sql語句中的group by要怎麼用!!
語法SELECT 欄位表 FROM 表 WHERE標准 [GROUP BY 分組欄位表]Group by 是SQL Server 中常用的一種擾肆語法,語法如下:[ GROUP BY [ ALL ] group_by_expression [ ,...n ] [ WITH { CUBE | ROLLUP } ]]
1、最常用的就是這種語法,如下:Select CategoryID, AVG(UnitPrice), COUNT(UnitPrice) FROM dbo.Procts Where UnitPrice > 30GROUP BY CategoryID ORDER BY CategoryID DESC這個語句查詢出,所有產品分類的產品平均單價,單價計數。並且單價在 30 以上的記錄。
2、再看看這種語法,如下:Select CategoryID, AVG(DISTINCT UnitPrice), COUNT(DISTINCT UnitPrice) FROM dbo.Procts Where UnitPrice > 30GROUP BY CategoryID ORDER BY CategoryID DESC使用 DISTINCT 的時候,將會去除重復的價格平均單價。
3、如果希望在分類統計之後,再使用條件過濾,下面的語句可以做為參數:Select CategoryID, SUM(UnitPrice) AS SumPriceFROM dbo.ProctsGROUP BY CategoryIDHAVING SUM(UnitPrice) > 300HAVING 與 Where 語句類似,Where 是在分類之前過濾,而 HAVING 是在分類之後過濾。它和 Where 一樣使用 AND、OR、NOT、LIKE 組合使用。
4、如果希望再在分類統計中,添加匯總行,可以使用以下語句:Select CategoryID, SUM(UnitPrice), GROUPING(CategoryID) AS 'Grouping'FROM dbo.ProctsGROUP BY CategoryID WITH ROLLUPGrouping 這一列用於標識出哪一行是匯總行。它使用 ROLLUP 操作添加匯總行。
5、如果使用 WITH CUBE 將會產生一個多維分類數據集,如下:Select CategoryID, SupplierID, SUM(UnitPrice) AS SumPriceFROM dbo.ProctsGROUP BY CategoryID, SupplierID WITH CUBE 它會產緩薯轎生一個手念交叉表,產生所有可能的組合匯總。
6、使用 ROLLUP CUBE 會產生一個 NULL 空值,可以使用以下語法解決,如下:Select CASE WHEN (GROUPING(SupplierID) = 1) THEN '-1' ELSE SupplierID END AS SupplierID, SUM(UnitPrice) AS QtySumFROM dbo.ProctsGROUP BY SupplierID WITH CUBE
它首先檢查當前行是否為匯總行,如果是就可以設置一個值,這里設置為 '-1' 。
Ⅱ sql語句中的groupby是什麼意思
一、sql語句中的groupby是:GROUP BY 語句用於結合合計函數,根據一個或多個列對結果集進行分組。
二、sql語句group by的高級語法:
1、寫上一個創建表的 sql語句. 當然,我們也可以用設計圖創建;

Ⅲ sql中order by和group by的區別
1、意思不一樣。
order by 是指從英文里理解就是行的排序方式,默認的為升序。後面必須列出排序的欄位名,可以是多個欄位名。
group by 是指從英文里理解就是分組。必須有「聚合函數」來配合才能使用,使用時至少需要一個分組標志欄位。
2、適用范圍不同:order by 用於排序,一般與asc升序或desc降序一起使用。例如select * from 表A order by 列a。
group by 用於分類匯總,一般與聚合函數(比如avg平均、sum合計、max最大、min最小、count計算行)一起使用。例如select 月份,sum(工資)as 總工資 from 工資表 group by 月份。
3、定義不同:order by主要側重許多數據的排序,例如按照大小順序對數據進行排列,group by主要側重許多數據的分組,例如按照性別、年齡、國家、學科等進行分組。
4、使用的函數不一樣。
order by子句中的列必須包含在聚合函數或 GROUP BY 子句中。
group by 子句中可使用的函數AVG() 、MIN() 、 MAX() 、SUM() 、COUNT() 。

5、order by從英文里理解就是行的排序方式,默認的為升序。order by後面必須列出排序的欄位名,可以是多個欄位名。
group by從英文里理解就是分組。必須有「聚合函數」來配合才能使用,使用時至少需要一個分組標志欄位。
(3)sql字元串groupby擴展閱讀
Microsoft Jet資料庫引擎SQL 數據類型 由13個基本數據類型組成,它們是由 Microsoft Jet 資料庫引擎和幾個驗證過的有效同義字定義的。常見的有:整形,單精度,雙精度,可變長度字元,固定長度字元,長型,日期等等。
可以用ALTER TABLE 語句修正基數和增量。剛插進表中的行會有自動為基於新種值和增量值的列生成的值。如果新種和增長的值和以前的種值及增量匹配,就會造成復制。如果這個列是主鍵,復制值生成時可能導致錯誤。
定義成TEXT也稱作MEMO)或CHAR(也稱作有具體長度的 TEXT(n))的欄位中的字元被儲存在 Unicode 表示格式。
Unicode字元一律需要兩個位元組存儲每一字元。對於現有的主要包含字元數據的 Microsoft Jet資料庫,這可能意味著資料庫文件被轉換成 Microsoft Jet 4.0格式時字長會增加將近一倍。
然而,從前由單位元組字元群(SBCS)指示的眾多字元群的Unicode 表示可以很容易地被壓縮成一個單位元組。有關的詳細信息,參見CREATE TABLE。如果用COMPRESSION屬性定義CHAR列,數據存儲時會自動被壓縮,提取時解壓縮。
Ⅳ sql語句中的group by什麼意思
分類匯總的時候用。group
by
:表示按欄位分組。例如:分別計算男性用戶和女性用戶的平均年齡。select
性別,avg(年齡)
as
average
from
表名
group
by
性別