GROUP BY (Transact-SQL)

更新日期: 2006 年 7 月 17 日

指定用来放置输出行的组。如果 SELECT 子句 <select list> 中包含聚合函数,则 GROUP BY 将计算每组的汇总值。指定 GROUP BY 时,选择列表中任意非聚合表达式内的所有列都应包含在 GROUP BY 列表中,或者 GROUP BY 表达式必须与选择列表表达式完全匹配。

ms177673.note(zh-cn,SQL.90).gif注意:
如果未指定 ORDER BY 子句,则使用 GROUP BY 子句返回的组没有任何特定的顺序。若要指定特定的数据排序,建议您始终使用 ORDER BY 子句。

主题链接图标Transact-SQL 语法约定

语法

[ GROUP BY [ ALL ] group_by_expression [ ,...n ] 
    [ WITH { CUBE | ROLLUP } ] 
] 

参数

  • ALL
    包含所有组和结果集,甚至包含那些其中任何行都不满足 WHERE 子句指定的搜索条件的组和结果集。如果指定了 ALL,将对组中不满足搜索条件的汇总列返回空值。不能用 CUBE 或 ROLLUP 运算符指定 ALL。

    如果在访问远程表的查询中还有 WHERE 子句,则该查询不支持 GROUP BY ALL。

  • group_by_expression
    进行分组所依据的表达式group_by_expression 也称为组合列。group_by expression 可以是列,也可以是引用由 FROM 子句返回的列的非聚合表达式。不能使用在选择列表中定义的列别名来指定组合列。

    ms177673.note(zh-cn,SQL.90).gif注意:
    不能在 group_by_expression 中使用类型为 textntextimage 的列。

    对于不包含 CUBE 或 ROLLUP 的 GROUP BY 子句,group_by_expression 的项数受查询所涉及的 GROUP BY 列的大小、聚合列和聚合值的限制。该限制从 8,060 字节的限制开始,对保存中间查询结果所需的中间级工作表有 8,060 字节的限制。如果指定了 CUBE 或 ROLLUP,则最多只能有 10 个分组表达式。

    不能直接在 group_by_expression 中指定 xml 数据类型方法。相反,可引用内部使用 xml 数据类型方法的用户定义函数,或引用使用这些数据类型方法的计算列。

  • CUBE
    指定在结果集内不仅包含由 GROUP BY 提供的行,还包含汇总行。GROUP BY 汇总行针对每个可能的组和子组组合在结果集内返回。GROUP BY 汇总行在结果中显示为 NULL,但用来表示所有值。使用 GROUPING 函数可确定结果集内的空值是否为 GROUP BY 汇总值。

    结果集内的汇总行数取决于 GROUP BY 子句内包含的列数。GROUP BY 子句中的每个操作数(列)绑定在分组 NULL 下,并且分组适用于所有其他操作数(列)。由于 CUBE 返回每个可能的组和子组组合,因此不论在列分组时指定使用什么顺序,行数都相同。

  • ROLLUP
    指定在结果集内不仅包含由 GROUP BY 提供的行,还包含汇总行。按层次结构顺序,从组内的最低级别到最高级别汇总组。组的层次结构取决于列分组时指定使用的顺序。更改列分组的顺序会影响在结果集内生成的行数。

    ms177673.note(zh-cn,SQL.90).gif重要提示:
    使用 CUBE 或 ROLLUP 时,不支持区分聚合,如 AVG(DISTINCT column_name)、COUNT(DISTINCT column_name) 和 SUM(DISTINCT column_name)。如果使用这类聚合,则 Microsoft SQL Server 2005 数据库引擎 将返回错误消息并取消查询。

示例

A. 使用简单 GROUP BY 子句

以下示例检索 SalesOrderDetail 表中各 SalesOrderID 的总数。

USE AdventureWorks ;
GO
SELECT SalesOrderID, SUM(LineTotal) AS SubTotal
FROM Sales.SalesOrderDetail sod
GROUP BY SalesOrderID
ORDER BY SalesOrderID ;

B. 将 GROUP BY 子句用于多个表

以下示例检索与 EmployeeAddress 表联接的 Address 表中的各 City 的雇员数。

USE AdventureWorks ;
GO
SELECT a.City, COUNT(ea.AddressID) EmployeeCount
FROM HumanResources.EmployeeAddress ea 
INNER JOIN Person.Address a
ON ea.AddressID = a.AddressID
GROUP BY a.City
ORDER BY a.City ;

C. 将 GROUP BY 子句用于表达式

以下示例使用 DATEPART 函数检索每年的销售总额。选择列表和 GROUP BY 子句中必须有相同的表达式。

USE AdventureWorks ;
GO
SELECT DATEPART(yyyy,OrderDate) AS Year,
SUM(TotalDue) AS AverageOrderAmt
FROM Sales.SalesOrderHeader
GROUP BY DATEPART(yyyy,OrderDate)
ORDER BY DATEPART(yyyy,OrderDate) ;

请参阅

参考

SELECT (Transact-SQL)
SELECT 子句 (Transact-SQL)

其他资源

使用 CUBE 汇总数据
使用 ROLLUP 汇总数据

帮助和信息

获取 SQL Server 2005 帮助

更改历史记录

发布日期 历史记录

2006 年 7 月 17 日

新增内容:
  • 添加了示例 C。

2005 年 12 月 5 日

更改的内容:
  • 修改了示例 B。