SQL Server GROUP BY子句与SELECT语句协作使用,以将相同的数据分组。
GROUP BY子句位于SELECT语句中的WHERE子句之后,位于ORDER BY子句之前。
语法
以下是GROUP BY子句的基本语法,GROUP BY子句必须遵循WHERE子句中的条件,并且必须在使用ORDER BY子句之前。SELECT column1, column2
FROM table_name
WHERE [ conditions ]
GROUP BY column1, column2
ORDER BY column1, column2
例
请参考具有以下记录的CUSTOMERS表:ID NAME AGE ADDRESS SALARY
1 Ramesh 32 Ahmedabad 2000.00
2 Khilan 25 Delhi 1500.00
3 kaushik 23 Kota 2000.00
4 Chaitali 25 Mumbai 6500.00
5 Hardik 27 Bhopal 8500.00
6 Komal 22 MP 4500.00
7 Muffy 24 Indore 10000.00
如果你想知道每个客户的工资总额,那么可以使用以下的GROUP BY查询方式:SELECT NAME, SUM(SALARY) as [sum of salary] FROM CUSTOMERS
GROUP BY NAME;
上述命令将产生以下结果集:NAME sum of salary
Chaitali 6500.00
Hardik 8500.00
kaushik 2000.00
Khilan 1500.00
Komal 4500.00
Muffy 10000.00
Ramesh 2000.00
现在让我们考虑存在重复名称的情况,请参考具有以下记录的CUSTOMERS表:ID NAME AGE ADDRESS SALARY
1 Ramesh 32 Ahmedabad 2000.00
2 Khilan 25 Delhi 1500.00
3 kaushik 23 Kota 2000.00
4 Chaitali 25 Mumbai 6500.00
5 Hardik 27 Bhopal 8500.00
6 Komal 22 MP 4500.00
7 Muffy 24 Indore 10000.00
如果我们想知道每个客户的工资总额,那么可以使用以下的GROUP BY查询方式:SELECT NAME, SUM(SALARY) as [sum of salary] FROM CUSTOMERS
GROUP BY NAME
上述命令将产生以下结果集:NAME sum of salary
Hardik 8500.00
kaushik 8500.00
Komal 4500.00
Muffy 10000.00
Ramesh 3500.00
本文介绍了SQLServer中GROUP BY子句的使用,它与SELECT语句结合用于将数据按特定列分组。在示例中,我们展示了如何通过GROUP BY查询从CUSTOMERS表中获取每个客户的工资总和。当存在重复名称时,GROUP BY能有效地聚合相同名字客户的薪水。
1950

被折叠的 条评论
为什么被折叠?



