当查询中存在group by子句时,select列表(或是having子句)中只能存在分组函数,或是出现在group by子句中的字段。

这里说的,“出现在group by子句中的字段”具体有两种形式出现:

1、select列表里直接出现一个以该字段名为列名的列,如:

select  La from test group by La;

1、select列表里出现一个非分组函数的函数的列,如:

select  La ,contact(La,La)from test group by La;

select  La ,contact(La,‘two’)from test group by La;

select  La ,contact(La,&tt)from test group by La;

注释:

当查询中存在group by子句时,非分组函数的参数值只能是from子句里各个表中出现在group by子句中的字段(变量)。而from子句里各个表中不出现在group by子句中的字段(变量)则不能为非分组函数的参数值,此时。而其他不是属于在表定义的变量(即表的列)的的变量,如上述的替换变量&tt,则可以为非分组函数的参数值。常量,可以为非分组函数的参数值,此时。

总之,当查询中存在group by子句时,只有from子句里各个表中不出现在group by子句中的字段(变量)不能为非分组函数的参数值。

当查询中存在group by子句时,分组函数,其参数值可以来自from子句里各个表中不出现在group by子句中的字段(变量)。

当查询中存在group by子句时,select列表中出现在group by子句中的字段组合值都是不重复的一条。例如,

select  La,Lb from test;

La  Lb

--    ---

a    3

a    9

b    2

b    3

b   12

select  La,sum(Lb) from test group by La;

La     sum(Lb)

--       ---

a       12

b       17

test里La为a,b值都是多条,经过group by后,结果集里La为a,b值总是都为一条。

这里,以select  La,sum(Lb) from test group by La;为例子,来描述group by的处理过程。大概过程如下:

先对test表上的数据行按列La进行排序即order by,再对非在group by子句中的字段进行聚合函数操作(如果group by子句所在select语句中存在聚合函数的话,会执行该步骤;不存在的话,就跳过不执行该步骤),这样,就对应输出一个列La的值(经过distinct操作这个步骤处理)和一个聚合函数返回值构成结果集A里的一行。聚合函数返回值都是一个的。

而select  La ,contact(La,‘two’)from test group by La;里的非分组函数contact所用的La的值是来自在该SQL语句中group by的处理过程执行完毕后对应输出的结果集A上一个列La的值,即非分组函数contact在结果集A基础上再进行处理获得该sql语句的最终一步结果集B。

再看如下例子,

SQL> select * from test; 

COUNTRY CITY 
-------------------- -------------------- 
中国 台北 
中国 香港 
中国 上海 
日本 东京 
日本 大阪

定义一个函数 
create or replace function str_list( str_in in varchar2 )--分类字段 
return varchar2 
is 
str_list varchar2(4000) default null;--连接后字符串 
str varchar2(20) default null;--连接符号 
begin 
for x in ( select TEST.CITY from TEST where TEST.COUNTRY = str_in ) loop 
str_list := str_list || str || to_char(x.city); 
str := ', '; 
end loop; 
return str_list; 
end; 
使用: 
SQL> select t.country,str_list(t.country) from test t GROUP BY t.country; 

COUNTRY STR_LIST(T.COUNTRY) 
-------------------- ----------------------- 
中国 台北, 香港, 上海 
日本 东京, 大阪 
这个时候,使用分组和求唯一都可以满足要求。它的原理就是,根据唯一的分组字段country,在str_list函数里面再次查询该字段对应的所有被合并列,使用PL/SQL将其合并输出,也就是说,在str_list函数里执行的select TEST.CITY from TEST where TEST.COUNTRY = str_in这个sql语句(对表test再次做查询)和select t.country,str_list(t.country) from test t GROUP BY t.country; 这个sql语句是相当于相互独立的两个sql语句在执行,前者不受后者里有GROUP BY 的影响,在执行str_list函数(里的select TEST.CITY from TEST where TEST.COUNTRY = str_in这个sql语句)时,外层的select t.country,str_list(t.country) from test t GROUP BY t.country; 这个sql语句除了select子句还没执行完(select子句执行完就获得该select语句的最终结果集了)外,其他子句都已经执行完,即 GROUP BY子句已经执行完获得了结果集A了,而外层的这个sql语句的select子句里执行的正是str_list函数。(select子句里的函数是否没查到一条数据行就立刻执行一次,而不是经过where等子句筛选出一个结果集后在执行,如case then?)

这两个sql语句也可以相当于前者是后者里的子查询,外层语句先开始执行,但子查询都是先于外层语句执行完毕的,故前者不受后者里有GROUP BY 的影响。(执行个带子查询和GROUP BY的查询语句试试,两层查询都对同个表?)

使用Group By注意事项的更多相关文章

  1. SQL其他常用的语句

    阅读目录 一:汇总数据 1.理解AVG函数 2.理解COUNT()函数 3.理解max()函数 4.理解min()函数 5.理解sum()函数 二:分组数据 1 创建分组(group by) 2 HA ...

  2. 分组查询以及having使用

    Group  by 注意事项:对查询的列有限制,除了聚合函数外,就必须是分组的项 order  by总是放在最后 代码示例: select Gender as 性别 ,count (Gender) a ...

  3. MySQL数据表查询操作

    准语法结构:编写DQL时一定要严格按照此语法的顺序来实现!/* SELECT [ALL | DISTINCT] ALL表示查询出所有的内容 DISTINCT 去重 {* | 表名.* | 表名.字段名 ...

  4. MySQL数据表查询操

    准语法结构:编写DQL时一定要严格按照此语法的顺序来实现!/* SELECT [ALL | DISTINCT] ALL表示查询出所有的内容 DISTINCT 去重 {* | 表名.* | 表名.字段名 ...

  5. mysql-数据分组

    一.创建分组 上面所讲的语句都是建立在表的所有数据或匹配特定的where子句的数据上进行的.是否能够进行分组,在进行汇总计算哪儿?例如:要想返回每个供应商提供的产品数目怎么办? 分组是在select语 ...

  6. MYSQL中GROUP BY不包含所有的非聚合字段时的注意事项

    本文导读:在MYSQL中使用GROUP BY分组时,我们可以select 多个非聚合字段,但是这些字段不在GROUP BY中,这样的SQL查询在SQL SERVER.ORACLE中是不合理的,且会报错 ...

  7. Group by、having、order by、Distinct 使用注意事项

    直奔主题,如下SQL语句 SELECT COUNT(*) AS COUNT,REQUEST,METHOD FROM REQUESTMETH GROUP BY REQUEST,METHOD HAVING ...

  8. SQL中group by的注意事项

    最最最最重要的: group by有一个原则,就是select后面所有的列中,没有使用聚合函数的列,必须出现在group by子句中. group by子句中的注意事项: 1,不能使用别名(因为执行顺 ...

  9. MySQL中MAX函数与Group By一起使用的注意事项(转)

    mysql> select * from test; +----+-------+------+-------+ | id | name | age | class | +----+------ ...

随机推荐

  1. Javascript、CSS和IMG之网页执行探索

    测试环境:windows/chrome 实例1:页面中仅有图片 <html xmlns="http://www.w3.org/1999/xhtml"> <head ...

  2. linux部分系统信息命令

    arch  显示机器的处理器架构9(1) uname -m 显示机器处理器架构(2) uname -r显示正在使用的内核版本 dmidecode -q 显示硬件系统部件 hdparm-i/dev/hb ...

  3. Excel 导入 Sql Server出错——“文本被截断,或者一个或多个字符在目标代码页中没有匹配项”错误的解决

    有人说应该先转成Access, 再转到Sql Server. 其实用处并不大, 要截断的还是被截断了. 原因是,SQL Server的导入导出为了确定数据表的字段类型,取excel文件的前8行来判别. ...

  4. win32记事本程序(一)

    我不会取标题,大体上我想用win32,模仿windows的记事本,写个记事本程序,最后让我的程序和微软的程序在外观和功能上都差不多.这样一来我可以学到一些新知识,巩固旧的知识. 一.首先做个菜单栏吧. ...

  5. 测试加载jquery

    Hello world! <h1 id="main-heading">Hello world!</h1> <p><img onclick= ...

  6. Linux下select&poll&epoll的实现原理(一)

    最近简单看了一把 linux-3.10.25 kernel中select/poll/epoll这个几个IO事件检测API的实现.此处做一些记录.其基本的原理是相同的,流程如下 先依次调用fd对应的st ...

  7. 细说php一些常见的知识点

    一.认识脚本语言 1.常见的脚本语言有:html,css,js,asp,Python等 2.脚本语言的特性: a.语法和机构通常比较简单 b.学习和使用通常比较简单 c.通常以容易修改程序的“解释”作 ...

  8. C# Lock 解读 (关键是理解最后一句)

    最近在研究.NET分布式缓存代码,正好涉及Lock,看了网上的文章,总结了一些Lock相关的知识,供大家一起学习参考. 一.Lock定义     lock 关键字可以用来确保代码块完成运行,而不会被其 ...

  9. new date() 在Linux下引起的时间差问题

    java工程部署到Linux时,使用new date()获取的时间出现时间差,通过查阅资料,发现有可能是服务器时间设置问题,JVM问题,jdk问题: 1.服务器时间设置问题: 正确的时间显示 有 CS ...

  10. Python实例1

    1.有1.2.3.4个数字,能组成多少个互不相同且无重复数字的三位数?都是多少? 错解: 正解: 源码: #!/usr/bin/python for i in range(1,5): for j in ...