SQL Server 基础 之 GROUP BY子句
GROUP BY 子句用于聚合信息
先看个实例,没有使用 GROUP BY 子句
SELECT SalesOrderID,OrderQty
FROM Sales.SalesOrderDetail
WHERE SalesOrderID IN (43660,43670)
结果: 结果可以得知,有很多重复的列(SalesOrderID)
为什么会出现这种结果了?
查看一下表结构可知,这张表 的主键是个组合主键, 分别有 SalesOrderID 和 SalesOrderDetailID 组成,当我们在 select中只选择SalesOrderID 时,所以会出现上图的结果
再来看使用了 GROUP BY 子句的结果:
SELECT SalesOrderID,OrderQty
FROM Sales.SalesOrderDetail
WHERE SalesOrderID IN (43660,43670)
GROUP BY SalesOrderID
此时会报错: 显示 OrderQty 列没有包含在 聚合函数 或 GROUP BY 子句中
说明: 当我们在使用 group by 子句的时候, select 中选取的列 要么要包含在 group by 子句中,要么要包含在 聚合函数中
此时我们修改代码:
SELECT SalesOrderID,OrderQty
FROM Sales.SalesOrderDetail
WHERE SalesOrderID IN (43660,43670)
GROUP BY SalesOrderID,OrderQty
结果: 这个实例包含了 group by 子句,但是没有 聚合函数
再来看看包含聚合函数的实例,通常有四个聚合函数
- SUM()
- MAX()
- MIN()
- COUNT()
在看一下:
SELECT SalesOrderID,SUM(OrderQty) AS TotalOrderQty
FROM Sales.SalesOrderDetail
WHERE SalesOrderID IN (43660,43670)
GROUP BY SalesOrderID
结果: 这个才算真正的分组了, 把每个 SalesOrderID 对应的 总OrderQty 显示出来了
先说说 GROUP BY 子句的作用:
它的作用是通过一定的规则将一个数据集划分成若干个小的区域,然后针对若干个小区域进行数据处理。
通过一个实例说明:
假设数据库中有张表结果如下:
由表中可分析出:
- ManagerID 为 1 的经理 有 3 名员工,其EmployeeID 分别为 2,3,4
- ManagerID 为 4 的经理 有 3 名员工,其EmployeeID 分别为 5,6,7
- ManagerID 为 5 的经理 有 4 名员工,其EmployeeID 分别为 8,9,10,11
- 员工号 EmployeeID 为 1 的员工 对应的 经理 ManagerID 为 NULL, 这点说明这名员工没有与之对应的经理, 可能是公司的总裁之类。
然后使用SQL 进行分析:
SELECT ManagerID, COUNT(*) --选出每个ManagerID,并且该MangerID所对应的数据条数
FROM HumanResources.Employee2
GROUP BY ManagerID --以 ManagerID 分组
结果如下:
说明: ManagerID 为1 有3条数据与之对应
ManagerID 为4 有3条数据与之对应
ManagerID为5 有4条数据与之对应
其中ManagerID 为NULL 的有一条数据与之对应, 假设为 总裁
- 添加HAVING 子句
HAVING 与 Where 语句类似,Where 是在分类之前过滤,而 HAVING 是在分类之后过滤。
如果想对以上返回结果,进行相应条件的搜索,则可以添加HAVING子句,假设这里需要返回 ManagerID 对应数据量 大于 3 的结果,则SQL如下:
SELECT COUNT(*) AS Reposrts
FROM HumanResources.Employee2
GROUP BY ManagerID
HAVING COUNT(*) > 3
结果:
SQL Server 基础 之 GROUP BY子句的更多相关文章
- Sql Server 基础语法
来自:http://www.cnblogs.com/AaronYang/archive/2012/04/24/2468093.html Sql Server 基础语法 -- 查看数据表 select ...
- SQL server基础知识(表操作、数据约束、多表链接查询)
SQL server基础知识 一.基础知识 (1).存储结构:数据库->表->数据 (2).管理数据库 增加:create database 数据库名称 删除:drop database ...
- 【SQL Server】SQL Server基础之存储过程
SQL Server基础之存储过程 阅读目录 一:存储过程概述 二:存储过程分类 三:创建存储过程 1.创建无参存储过程 2.修改存储过程 3.删除存储过程 4.重命名存储过程 5.创建带参数的存储 ...
- SQL Server 2012 中 Update FROM子句
首先说明一下需求以及环境 创建Table1以及Table2两张表,并插入一下数据 USE AdventureWorks2012; GO IF OBJECT_ID ('dbo.Table1', 'U') ...
- 《SQL Server基础——SQL语句》
SQL Server基础--SQL语句 一.创建和删除数据库: 1.创建数据库(默认化初始值) 格式: CREATE DATABASE 数据库名称 例如: CREATE DATABASE ...
- 数据库开发基础-SQl Server 基础
SQL Server 基础 1.什么是SQL Server SQL:Structured Query Language 结构化查询语言 SQL Server是一个以客户/服务器(c/s)模式访问.使 ...
- Sql Server 基础知识
Sql Server 基础知识: http://blog.csdn.net/t6786780/article/details/4525652 Sql Server 语句大全: http://www.c ...
- SQL Server基础之索引
索引用于快速找出在某个列中有某一特定值的行,不使用索引,数据库必须从第一条记录开始读完整个表,直到找出相关的行.表越大,查询数据所花费的时间越多,如果表中查询的列有一个索引,数据库能快速到达一个位置 ...
- 【SQL server】SQL server基础(二)
一.一些重要的SQL命令 SELECT - 从数据库中提取数据 UPDATE - 更新数据库中的数据 DELETE - 从数据库中删除数据 INSERT INTO - 向数据库中插入新数据 CREAT ...
随机推荐
- 5 给我们的c#程序添加注释
注释是你的程序中的一个重要部分.在程序中添加注释是用来告诉你和其他人你的程序是做什么用的,你的思路是怎样的.注释可以用你熟悉的中文进行添加. 当你想暂时把你程序中的某些语句去掉的时候,不需要把他们删除 ...
- Python实现NN(神经网络)
Python实现NN(神经网络) 参考自Github开源代码:https://github.com/dennybritz/nn-from-scratch 运行环境 Pyhton3 numpy(科学计算 ...
- android NDK开发环境搭建
android NDK开发环境搭建 2012-05-14 00:13:58 分类: 嵌入式 基于 Android NDK 的学习之旅-----环境搭建 工欲善其事必先利其器 , 下面介绍下 Eclip ...
- python学习笔记1
python3.3使用urllib2报错 no module named urllib2,原因是python3中将urllib2换成了request. 所以要使用import urllib.reque ...
- html转义函数
public static String filter(String message) { if (message == null) return (null); char content[] = n ...
- 小组开发项目针对性的NABC分析
单独就我们团队开发项目——重力解锁的功能特点而言,我们解决了智能手机屏幕解锁的乏味和繁琐的特点,显得更有趣味性和独特性,更符合现代人追随时尚的潮流:我们根据个人的不同喜好和便利性来设定一些动作,利用重 ...
- 通过HTML5获取当前位置
// 当前位置 function getLocation() { if (navigator.geolocation) { navigator.geolocation.getCurrentPositi ...
- 【Exception】 java.lang.NoSuchMethodError: android.app.AlertDialog$Builder.setOnDismissListener
f(Build.VERSION.SDK_INT >10) builder =newAlertDialog.Builder(getActivity(), R.style.Theme.Sherloc ...
- 20、android解决方案(转载)
目录: 1.广告 2.推送 3.云 4.统计 5.后端存储 6.地图 7.测试 8.托管 9.支付 10.音视频 11.社会化分享 12.存储 13.自动更新 14.轻开发 15.安全 16.图像 1 ...
- 【BZOJ】【1019】【SHOI2008】汉诺塔
递推/DP 类似普通汉诺塔的一个递推(模拟?$10^{18}$没法模拟吧…… 题解:http://blog.csdn.net/regina8023/article/details/43016813 因 ...