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(分组). ...
随机推荐
- Java DB 访问之(四) spring mvc 组合mybatis
说明 本项目采用 maven 结构,主要演示了 spring mvc + mybatis,controller 获取数据后以json 格式返回数据. 项目结构 包依赖 与说明 pom文件: <p ...
- BZOJ3916: [Baltic2014]friends
题目:http://www.lydsy.com/JudgeOnline/problem.php?id=3916 复习一下hash(然后被傻叉错误卡了半天TAT... 取出一个字串:h[r]-h[l-1 ...
- linux基本命令学习02
=============================================================================a.txtc:\abc\a.txt windo ...
- MIT公开课:算法导论 笔记(一)
课程链接:http://open.163.com/special/opencourse/algorithms.html 第一课:算法分析基础 1.介绍插入排序与归并排序,计算并比较最坏运行时间 2.算 ...
- eclipse中git提交冲突问题
1.工程->Team->同步: 2.从远程pull至本地,就会出现如下内容: 3.使用Merge Tool,执行第二项 使用HEAD合并后的效果: 4.再手动修改 4.修改后的文件需要 ...
- Java Thread wait、notify与notifyAll
Java的Object类包含了三个final方法,允许线程就资源的锁定状态进行通信.这三个方法分别是:wait(),notify(),notifyAll(),今天来了解一下这三个方法.在任何对象上调用 ...
- [国嵌笔记][017][Makefile工程管理]
Makefile的用途 1.make能够使整个程序的编译.链接只需一个命令就可以完成 2.make的工作主要依赖于Makefile的文件.Makefile文件描述了整个程序的编译.链接等规则,使之自动 ...
- mac android studio 出现 Error: SDK location not found. Define location with sdk.dir in the local.properties file or with an ANDROID_HOME environment variable.
Error: SDK location not found. Define location with sdk.dir in the local.properties file or with a ...
- 手把手教你搭建 vue 环境
第一步 node环境安装 1.1 如果本机没有安装node运行环境,请下载node 安装包进行安装1.2 如果本机已经安装node的运行换,请更新至最新的node 版本下载地址:https://nod ...
- Django框架之正则表达式URL误区
问题:我学习的视频大概是2015年录的,里面用的Django版本比较老关于正则表达式URL这一块都是用的url("url(r'^admin/', admin.site.urls)," ...