oracle的分组查询和连接查询
分组函数:
六个常用的分组函数:
AVG,SUM,MIN,MAX,COUNT,WM_CONCAT: 行转列
PS:分组函数默认会自动过滤控制,可以使用NVL函数使分组函数无法忽略空值:
未使用NVL函数: select sum(comm)/count(*) 一,sum(comm)/count(comm) 二,avg(comm) 三 from emp; --若有空记录,第一个结果和二三结果的不同
使用NVL函数: select count(*) 一, count(nvl(comm,0)) 二 from emp;
分组函数的语法格式 :
PS:未包含在分组函数的列,必须要在group by子句后面
select a,b,c ,分组函数(d) from emp group by a,b,c;
如何过滤分组数据: having
PS: having与where的区别: where子句中不能使用分组函数,having必须和group by联用
select deptno,avg(sal) from emp group by deptno having avg(sal) >4000
order by
select deptno,avg(sal) from emp group by deptno order by avg(sal)
分组函数的嵌套:
select max(avg(sal)) from emp group by deptno;
group by增强:
PS: group by rollup(a,b) 等价于 group by a,b +group by a, group by null
select deptno,job,sum(sal) from emp group by rollup(deptno,job);
查询结果如下:
10 CLERK 2689.2
10 MANAGER 4807.96
10 PRESIDENT 6084.64
10 13581.8
20 CLERK 5456.11
20 ANALYST 6736.6
20 MANAGER 5093.17
20 17285.88
30 CLERK 2728.04
30 MANAGER 5025.26
30 SALESMAN 11261.79
30 19015.09
49882.77
多表查询:
笛卡尔积的概念:笛卡尔积就是列数相加,行数相乘
例如两张表emp,dept的数据如下是:


笛卡尔积的数据的sql如下
select * from emp,dept
结果如下:共56行数据

连接类型:
等值连接: e.deptno = d.deptno
不等值连接 : from emp e, salgrade s where e.sal > s.losal and e.sal < s.hisal
外链接 : 通过外链接,把对于连接条件不成立的记录,任然包含在最后的结果中
左外链接:=(+)
右外连接: (+)= : 下方的例子若不用右连接则查不出来两边表中不存在的deptno的记录
右连接的作用: select d.deptno 部门号,d.dname 部门名称,count(e.empno) 人数
from emp e, dept d
where e.deptno (+)=d.deptno
group by d.deptno,d.dname;
查询结果如下:

若是不用右连接,sql语句中少了"(+)",则查询结果如下:

自连接:通过别名,将同一张表视为多张表
select e.ename 员工姓名, b.ename 老板姓名
from emp e ,emp b
where e.mgr = b.empno
查询结果如下:

自连接缺点:不适合操作大表,一张表做一次自连接 笛卡尔积会是记录的平方;做两次自连接笛卡尔积是记录的立方
解决方法:层次查询
--上一层的员工号(prior empno)是当前层的老板号(mgr) --level 伪列字段:表中不存在的字段 代表当前记录的的层级
select level,empno,ename,sal,mgr
from emp
connect by prior empno = mgr
start with empno = 7839
order by 1;
查询结果如下:

1)与自连接优点:是单表查询,不会产生笛卡尔积
2)与自连接缺点:结果不直观
自连接与层级查询对比的优点:结果比较直观
oracle的分组查询和连接查询的更多相关文章
- 关系数据库SQL之高级数据查询:去重复、组合查询、连接查询、虚拟表
前言 接上一篇关系数据库SQL之基本数据查询:子查询.分组查询.模糊查询,主要是关系型数据库基本数据查询.包括子查询.分组查询.聚合函数查询.模糊查询,本文是介绍一下关系型数据库几种高级数据查询SQL ...
- Mysql的查询语句(联合查询、连接查询、子查询等)
Mysql的各个查询语句(联合查询.连接查询.子查询等) 一.联合查询 关键字:union 语法形式 select语句1 union[union选项] select 语句2 union[union选项 ...
- mysql查询、子查询、连接查询
mysql查询.子查询.连接查询 一.mysql查询的五种子句 where子句(条件查询):按照“条件表达式”指定的条件进行查询. group by子句(分组):按照“属性名”指定的字段进行分组.gr ...
- mysql 子句、子查询、连接查询
一.mysql查询的五种子句 where子句(条件查询):按照“条件表达式”指定的条件进行查询. group by子句(分组):按照“属性名”指定的字段进行分组.group by子句通常和count( ...
- 【知识库】-数据库_MySQL之高级数据查询:去重复、组合查询、连接查询、虚拟表
简书作者:seay 文章出处: 关系数据库SQL之高级数据查询:去重复.组合查询.连接查询.虚拟表 回顾:[知识库]-数据库_MySQL之基本数据查询:子查询.分组查询.模糊查询 Learn [已经过 ...
- MSSQLServer基础05(联合查询,连接查询)
联合结果集union(集合运算符) 集合运算符是对两个集合操作的,两个集合必须具有相同的列数,列具有相同的数据类型(至少能隐式转换的),最终输出的集合的列名由第一个集合的列名来确定.(可以用来连接多个 ...
- 图解SQLSERVER联合查询和连接查询的区别
相信很多人都会用SQLSERVER联合查询和连接查询,但是用起来不一定都得心应手,对于其中的原理可能就模糊不清了,要想很牢固地掌握和运用SQL联合查询和连接查询机制,必须对其根本原理有很清晰认识, ...
- MySQL分组查询与连接查询
一,分组查询 使用ORDER BY子句将表中的数据分成若干组(还是按行显示) 语法: SELECT 字段名[,聚集函数] FROM 表名 [WHERE子句] GROUP BY 要分组的字段名 [ORD ...
- ORACLE复杂查询之连接查询
一.传统的连接查询 1.交叉连接:返回笛卡尔积 WHERE中限定查询条件,可以预先过滤掉掉不符合条件的记录,返回的只是两个表中剩余记录(符合条件的记录)的笛卡尔积. 2.内连接:参与连接的表地位平等, ...
- mysql的查询、子查询及连接查询
>>>>>>>>>> 一.mysql查询的五种子句 where(条件查询).having(筛选).group by(分组). ...
随机推荐
- 模块(一)——re模块
re模块下的常用方法: import re ret = re.findall('a', 'eva egon yuan') # 返回所有满足匹配条件的结果,放在列表里 print(ret) #结果 : ...
- CodeChef June Challenge 2017
好气啊,本来以为比赛时间还有很多,结果回家养病两天回到学校怎么比赛就结束了(雾),大约是小高考弄错了时间? 挑3道有意思的写写题解吧. Cloning 题目大意:给一个序列,每次询问两个等长区间,问区 ...
- BZOJ 3105: [cqoi2013]新Nim游戏
题目:http://www.lydsy.com/JudgeOnline/problem.php?id=3105 题意是要取一些数使得剩余的数xor和的子集不为0 拟阵.求解极大线性无关组.贪心从大到小 ...
- 最短路(spfa)
http://acm.hdu.edu.cn/showproblem.php?pid=2544 最短路 Time Limit: 5000/1000 MS (Java/Others) Memory ...
- maven(01)--安装及其介绍
1:下载maven windows下载 2:将下载文件夹解压,然后放在一个安装目录(可任意选择),例如就放在D盘的根目录 然后在设置环境变量,新建一个环境变量,名称为M2_HOME,其设置值为mave ...
- 【程序员的吃鸡大法】利用OCR文字识别+百度算法搜索,玩转冲顶大会、百万英雄、芝士超人等答题赢奖金游戏
[先上一张效果图]: 一.原理: 其实原理很简单: 1.手机投屏到电脑: 2.截取投屏画面的题目部分,进行识别,得到题目和三个答案: 3.将答案按照一定的算法,进行搜索,得出推荐答案: 4.添加了一些 ...
- 一对多(多对一)关系中的inverse和cascade属性
转载请标明出处 http://www.cnblogs.com/haozhengfei/p/6049276.html 首先说一下inverse: "inverse" 直译过来就是&q ...
- 解决DEDECMS Call to undefined function dede_htmlspecialchars()
作者:DEDECMS建站网 关注: 3610 时间:2015-11-18 16:39 内容详情 以下内容您可能感兴趣: 织梦官方在2015年6月18日更新了织梦5.7,为了兼容php5.4+,修改了/ ...
- “此主机支持 Intel VT-x,但 Intel VT-x 处于禁用状态”的问题的解决
虚拟机使用的是VMware Workstation,并且首次在虚拟机体验64 位系统.在新建好虚拟机,运行时候就出现了VMware Workstation 的提醒:此主机支持 Intel VT-x,但 ...
- Css雪碧图
Css雪碧图: CSS雪碧 即CSS Sprite,也有人叫它CSS精灵,是一种CSS图像合并技术,该方法是将小图标和背景图像合并到一张图片上,然后利用css的背景定位来显示需要显示的图片部分. 原理 ...