当查询中存在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. Objective C运行时(runtime)

    #import <objc/runtime.h> void setBeingRemoved(id __self, SEL _cmd) { NSLog(@"------------ ...

  2. win32记事本程序(一)

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

  3. C++学习笔记30:模板与型式参数化

    转型操作 接受目标型式作为模板参数 Programmer *p = dynamic_cast<Programmer*>(e) 模板工作原理 使用template<typename T ...

  4. linux 查找文件与进程常用命令

    Linux的五个查找命令 1. find find是最常见和最强大的查找命令,你可以用它找到任何你想找的文件. find的使用格式如下: $ find <指定目录> <指定条件> ...

  5. Android技术积累:开发规范

    转载自Keegan小钢 http://keeganlee.me/post/android/20150709 书写规范 1. 编码方式统一用UTF-8. Android Studio默认已是UTF-8, ...

  6. 深入理解 C 语言的函数调用过程

    来源: wjlkoorey 链接:http://blog.chinaunix.net/uid-23069658-id-3981406.html 本文主要从进程栈空间的层面复习一下C语言中函数调用的具体 ...

  7. myeclipse打war包时,报错security alert integrity check error

    今天在用myeclipse打包项目时,出现如下图的提示: 在网上查找了一下原因,主要是由于Jar包不符合所导致的.解决办法如下: 将com.genuitec.eclipse.export.wizard ...

  8. Python实例2

    2.企业发放的奖金根据利润提成.利润(I)低于或等于10万元时,奖金可提10%:利润高于10万元,低于20万元时,低于10万元的部分按10%提成,高于10万元的部分,可提成7.5%:20万到40万之间 ...

  9. kernel/vsprintf.c

    /* *  linux/kernel/vsprintf.c * *  Copyright (C) 1991, 1992  Linus Torvalds */ /* vsprintf.c -- Lars ...

  10. 1 error C4996: 'pcl::SAC_SAMPLE_SIZE':

    使用PCL1.8   中使用粗配准拼接 错误 1 error C4996: 'pcl::SAC_SAMPLE_SIZE': This map is deprecated and is kept onl ...