group by 两个字段
group by 的简单说明: group by 一般和聚合函数一起使用才有意义,比如 count sum avg等
使用group by的两个要素:
(1) 出现在select后面的字段 要么是是聚合函数中的,要么就是group by 中的.
(2) 要筛选结果 可以先使用where 再用group by 或者先用group by 再用having
下面看下 group by多个条件的分析:
---------- 测试数据初始化 begin --------------------
在SQL查询器输入以下语句
create table test1
(
a varchar2(20),
b varchar2(20),
c varchar2(20)
);
insert into test1 values(1,'a','甲');
insert into test1 values(1,'a','甲');
insert into test1 values(1,'a','甲');
insert into test1 values(1,'a','甲');
insert into test1 values(1,'a','乙');
insert into test1 values(1,'b','乙');
insert into test1 values(1,'b','乙');
insert into test1 values(1,'b','乙');
---------- 测试数据初始化 end--------------------
第一次查询
select * from test1; 结果如下图:
结果中 按照b列来分:则是 5个a 3个b. 按照c列来分:则是 4个甲 4个乙.
第二次查询 按照 b列来分组 代码如下
select count(a),b from test1 group by b;
第三次 按照 c列来分组 代码如下
select count(a),c from test1 group by c;
第四次 按照 b c两个条件来分组
select count(a),b,c from test1 group by b,c;
可以看出 group by 两个条件的工作过程:
先对第一个条件b列的值 进行分组,分为 第一组:1-5, 第二组6-8,
然后又对已经存在的两个分组用条件二 c列的值进行分组,发现第一组又可以分为两组 1-4,5
第五次 按照 c b 顺序分组
select count(a),b,c from test1 group by c,b;
最新文章
- iOS开发中遇到的错误整理 - 集成第三方框架时,编译后XXX头文件找不到
- hdu3415 单调队列
- bzoj4402: Claris的剑
- hdu 1711Number Sequence
- 《BI项目笔记》历年的初烟水分均值变化分析Cube的建立
- ELK 信息统计分析-1
- linux包之bash之内置命令ulimit
- 【jmeter】测试报告优化<;一>;
- find命令之exec
- 1304: [CQOI2009]叶子的染色 - BZOJ
- padding and margin.
- android studio集成环境搭建
- C# 对JS编码/解码进行转换
- function的粗浅理解
- HTML常见标签学习与笔记总结
- 在windows下用C语言写socket通讯实例
- Visual Studio 2013 Use HTTPS (SSL) On Web Application Projects
- 读headFirst设计模式 - 观察者模式
- Mego开发文档 - 事务
- JS中如何进行对象的深拷贝