`

SQL语句:Group By总结(1)

阅读更多

1. Group By 语句简介:

Group By语句从英文的字面意义上理解就是根据(by)一定的规则进行分组(Group)”。它的作用是通过一定的规则将一个数据集划分成若干个小的区域,然后针对若干个小区域进行数据处理。

P.S. 这里真是体会到了一个好的命名的力量,Group By从字面是直接去理解是非常好理解的。恩,以后在命名的环节一定要加把劲:)。话题扯远了。

2. Group By 的使用:

上面已经给出了对Group By语句的理解。基于这个理解和SQL Server 2000的联机帮助,下面对Group By语句的各种典型使用进行依次列举说明。

2.1 Group By [Expressions]:

这个恐怕是Group By语句最常见的用法了,Group By + [分组字段](可以有多个)。在执行了这个操作以后,数据集将根据分组字段的值将一个数据集划分成各个不同的小组。比如有如下数据集,其中水果名称(FruitName)和出产国家(ProductPlace)为联合主键

 

FruitName

ProductPlace

Price

Apple

China

$1.1

Apple

Japan

$2.1

Apple

USA

$2.5

Orange

China

$0.8

Banana

China

$3.1

Peach

USA

$3.0

如果我们想知道每个国家有多少种水果,那么我们可以通过如下SQL语句来完成:

SELECT     COUNT(*AS 水果种类, ProductPlace AS 出产国
FROM         T_TEST_FRUITINFO
GROUP BY ProductPlace

这个SQL语句就是使用了Group By + 分组字段的方式,那么这句SQL语句就可以解释成我按照出产国家(ProductPlace)将数据集进行分组,然后分别按照各个组来统计各自的记录数量。很好理解对吧。这里值得注意的是结果集中有两个返回字段,一个是ProductPlace(出产国), 一个是水果种类。如果我们这里水果种类不是用Count(*),而是类似如下写法的话:

SELECT FruitName, ProductPlace FROM T_TEST_FRUITINFO GROUP BY ProductPlace

那么SQL在执行此语句的时候会报如下的类似错误:

选择列表中的列 'T_TEST_FRUITINFO.FruitName' 无效,因为该列没有包含在聚合函数或 GROUP BY 子句中。

这就是我们需要注意的一点,如果在返回集字段中,这些字段要么就要包含在Group By语句的后面,作为分组的依据;要么就要被包含在聚合函数中。我们可以将Group By操作想象成如下的一个过程,首先系统根据SELECT 语句得到一个结果集,如最开始的那个水果、出产国家、单价的一个详细表。然后根据分组字段,将具有相同分组字段的记录归并成了一条记录。这个时候剩下的那些不存在于Group By语句后面作为分组依据的字段就有可能出现多个值,但是目前一种分组情况只有一条记录,一个数据格是无法放入多个数值的,所以这里就需要通过一定的处理将这些多值的列转化成单值,然后将其放在对应的数据格中,那么完成这个步骤的就是聚合函数。这就是为什么这些函数叫聚合函数(aggregate functions)了。

2.2 Group By All [expressions]

Group By All + 分组字段, 这个和前面提到的Group By [Expressions]的形式多了一个关键字ALL。这个关键字只有在使用了where语句的,且where条件筛选掉了一些组的情况才可以看出效果。在SQL Server 2000的联机帮助中,对于Group By All是这样进行描述的:

如果使用 ALL 关键字,那么查询结果将包括由 GROUP BY 子句产生的所有组,即使某些组没有符合搜索条件的行。没有 ALL 关键字,包含 GROUP BY 子句的 SELECT 语句将不显示没有符合条件的行的组。

其中有这么一句话如果使用ALL关键字,那么查询结果将包含由Group By子句产生的所有组...没有ALL关键字,那么不显示不符合条件的行组这句话听起来好像挺耳熟的,对了,好像和LEFT JOIN RIGHT JOIN 有点像。其实这里是类比LEFT JOIN来进行理解的。还是基于如下这样一个数据集:

FruitName

ProductPlace

Price

Apple

China

$1.1

Apple

Japan

$2.1

Apple

USA

$2.5

Orange

China

$0.8

Banana

China

$3.1

Peach

USA

$3.0

首先我们不使用带ALL关键字的Group By语句:

SELECT     COUNT(*AS 水果种类, ProductPlace AS 出产国
FROM         T_TEST_FRUITINFO
WHERE     (ProductPlace <> 'Japan')
GROUP BY ProductPlace

那么在最后结果中由于Japan不符合where语句,所以分组结果中将不会出现Japan

现在我们加入ALL关键字:

SELECT     COUNT(*AS 水果种类, ProductPlace AS 出产国
FROM         T_TEST_FRUITINFO
WHERE     (ProductPlace <> 'Japan')
GROUP BY ALL ProductPlace

重新运行后,我们可以看到Japan的分组,但是对应的水果种类不会进行真正的统计,聚合函数会根据返回值的类型用默认值0或者NULL来代替聚合函数的返回值

分享到:
评论

相关推荐

    SQL GROUP BY 语句

    SQL GROUP BY 语句 SQL GROUP BY 语句

    SQL语句中Group BY 和Rollup以及cube用法

    SQL语句中Group BY 和Rollup以及cube用法

    简单讲解sql语句中的group by的使用方法

    group by 就是依据by 后面的规则对数据分组,所谓的分组就是讲数据集划分成若干个’小组’,针对若干个小组做处理。 2.语法规则 SELECT column_name, aggregate_function(column_name) FROM table_name WHERE ...

    MySQL中查询所有数据库占用磁盘空间大小和单个库中所有表的大小的sql语句

    select TABLE_SCHEMA, concat(truncate(sum(data_length)/1024/1024,2),’ MB’) as data_size,concat(truncate(sum(index_length)/1024/1024,2),’MB’) as index_sizefrom information_schema.tablesgroup by ...

    SQL GROUP BY 语句详解

    SQL GROUP BY 语法

    sql语句生成器+支持各大数据库+说明书

    SQL语句生成器的特色 支持几乎所有类型的数据库, 包括小型(桌面)数据库:Fox DBF、Microsoft Execl、Text、Borland Paradox、 中型数据库:Microsoft Access 大型数据库:Microsoft SQL Server、Sybase、Oracle ...

    SQL语句生成及分析器

    无论多么复杂的语句,都能分析出来(包括SQL各子句中嵌套的SQL语句) 5、数据库视图定义和重建 6、支持将SQL查询语句,替换为插入(Insert into)和更新(Update)语句 7、附属工具内嵌入Delphi IDE(支持Delphi 5和...

    经典SQL语句大全

    10、说明:几个简单的基本的sql语句 选择:select * from table1 where 范围 插入:insert into table1(field1,field2) values(value1,value2) 删除:delete from table1 where 范围 更新:update table1 set field1...

    SQL语句中Group BY 和Rollup以及cube用法.txt

    SQL Server中的用法为group by colomn with [rollup|cube],首先要弄明白rollup 和cube,就要知道group by的用法,group by 为对列进行分组,只展现分组统计的值,而 rollup 为分层次展现,cube 为展现列中所有层次...

    SQL常用语句.zip

    sql语句 SQL(Structured Query Language,结构化查询语言)是用于管理关系数据库的标准编程语言。下面将介绍一些SQL的常用语句,包括数据查询、数据操作、数据定义和数据控制等方面 一、数据查询语句 SELECT语句...

    SQL语句自动生成工具

    无需安装和卸载 支持几乎所有的SQL语法: 排序(Order By) 条件(Where) 分组(Group By) 分组条件(Having) 计算字段 SQL查询表 SQL查询子句 丰富的函数 表别名 字段别名(包括计算...

    PHP100视频教程 9:数据库中的常用SQL语句.rar

    分组语句:group by 字段 排序语句:order by 字段,字段 ASC / DESC 指针查询:limit 初始值,结束值 计算:  COUNT(*) 统计函数  MAX(*) 最大值函数  MIN (*) 最小值函数  AVG(*) 平均值函数  SUM(*)...

    常用SQL 语句大全

    10、几个简单的基本的sql语句 11、几个高级查询运算词 12、使用外连接 13、分组:Group by: 14、对数据库进行操作: 15.如何修改数据库的名称: 第二部分、 提升 1、复制表 2、拷贝表 3、跨数据库之间表的...

    SQL语句自动生成器简体中文版

    无需安装和卸载 支持几乎所有的SQL语法: 排序(Order By) 条件(Where) 分组(Group By) 分组条件(Having) 计算字段 SQL查询表 SQL查询子句 丰富的函数 表别名 字段别名(包括计算...

    50个常用sql语句_答案

    常用的sql语句大全,select / update/delete/order by/group by / jion in /alert / 等等

    LINQ to SQL手册

    LINQ to SQL语句(6)之Group By/Having LINQ to SQL语句(7)之Exists/In/Any/All/Contains LINQ to SQL语句(8)之Concat/Union/Intersect/Except LINQ to SQL语句(9)之Top/Bottom和Paging和SqlMethods LINQ to SQL语句...

    经典全面的SQL语句大全

    经典SQL语句大全 下列语句部分是Mssql语句,不可以在access中使用。  SQL分类:  DDL—数据定义语言(CREATE,ALTER,DROP,DECLARE)  DML—数据操纵语言(SELECT,DELETE,UPDATE,INSERT)  DCL—数据控制...

    深入浅析SQL中的group by 和 having 用法

    一、sql中的group by 用法解析:  Group By语句从英文的字面意义上理解就是“根据(by)一定的规则进行分组(Group)”。  作用:通过一定的规则将一个数据集划分成若干个小的区域,然后针对若干个小区域进行数据处理...

    Mysql中错误使用SQL语句Groupby被兼容的情况

    本文给大家带来了Mysql中错误使用SQL语句Groupby被兼容的情况,及sql的grop by 语句介绍。感兴趣的朋友一起通过本文学习吧

Global site tag (gtag.js) - Google Analytics