07-oracle多表查询
--笛卡尔积,多表查询时,n张表中的行数相乘(本例中14*4=56)
--多表查询时笛卡尔积无法消除,即使使用了限定条件(where)也只是不显示而已,实际上笛卡尔积仍存在
--只能使用合理的做法来处理多表查询。
--多表查询时,每当增加一张关联表时都需要设置一个消除笛卡儿积的条件。
select count(*) from emp;
14
select count(*) from dept;
4
select count(*) from emp,dept;
--查询员工姓名,工作,工资等级编号,工资等级范围
select e.ename,e.job,e.sal,s.grade,s.losal,s.hisal
from emp e,salgrade s
where e.sal between s.losal and s.hisal
--查询员工姓名,工作,工资等级编号,工资等级范围
--将等级用中文显示(如:<1200的为E等工资)
select e.ename,e.job,e.sal,s.grade,s.losal,s.hisal,
decode(s.grade,
1,'E等',
2,'D等',
3,'C等',
4,'B等',
5,'A等'
) 工资等级
from emp e,salgrade s
where e.sal between s.losal and s.hisal;
--内连接:等值连接,不显示不匹配的行。
--外连接:左外连接,右外连接,全外连接,通过(+)符号进行控制
--emp插入部门为null的‘中华’员工信息
insert into emp(empno,ename,job,mgr,hiredate,sal,comm,deptno)
values('8888','中华','manager','9888',to_date('2019/1/1','yyyy-mm-dd'),'5000','1000',null);
commit;
--通过deptno关联查询时由于用户‘中华’的deptno为null,所以结果中未显示此用户的信息
select *
from emp e,dept d
where e.deptno=d.deptno;
--通过左连接,可以将没有关联的‘中华’用户的信息也显示出来
select *
from emp e,dept d
where e.deptno=d.deptno(+);
--右外连接,无用户属于dept表中deptno为40的部门,通过e.deptno=d.deptno时由于无匹配关联,所以deptno为40的行不会显示,通过右外连接显示此部门信息
-
--自连接,查询emp员工对应领导的编号和领导姓名,因为king无领导若不采用外连接(+),king的信息会不显示
select * from emp;
select e.ename,e.job,e.empno,e.mgr,m.empno,m.ename
from emp e,emp m
where e.mgr=m.empno(+);
--分析要求,逐步查出
select e.empno,e.ename,to_char(e.hiredate,'yyyy-mm-dd') hiredate,e.job,
m.ename,e.sal,nvl2(e.comm,e.sal+e.comm,e.sal)*12 income,
decode (s.grade,'1','A',2,'B',3,'C',4,'D') Slevel,d.deptno,d.dname,d.loc
from emp e,emp m,salgrade s,dept d
where /*e.hiredate like '%81%'*/ to_char(e.hiredate,'yyyy')='1981'
and e.mgr=m.empno
and e.sal between s.losal and s.hisal
and e.deptno=d.deptno
and e.sal between 1500 and 3500
order by income desc, e.job;
--SQL1999语法:
--emp 表有14行数据,dept表有4行数据
--交叉连接 cross join功能:产生笛卡儿积
select * from emp cross join dept;
--自然连接:natural join功能:消除笛卡儿积,等值字段放在查询结果的第一列
select * from emp natural join dept;
--using:没有关联的多表查询时,using将表关联并消除笛卡儿积
select * from emp join dept using(deptno)
--on:
select * from emp e join salgrade s on (e.sal between s.losal and s.hisal);
--全外连接:
--左外连接2种写法
select *
from emp e,dept d
where e.deptno=d.deptno(+);
--sql1999语法左外连接:
select * from emp e left outer join dept d on (e.deptno=d.deptno);
--sql1999语法右外连接:
select * from emp e right outer join dept d on (e.deptno=d.deptno);
--sql1999语法全外连接:
select * from emp e full outer join dept d on (e.deptno=d.deptno);
--建议使用union或union all 替代or
--集合操作时查询返回的数据结构要求一致
--数据的集合运算
--并集操作union(不显示重内容):返回若干个查询结果的全部内容,重复部分不显示
select * from dept
union
select * from dept d where d.deptno='10'
--并集操作union all(显示重复内容):返回若干个查询结果的全部内容,显示重复行
select * from dept
union all
select * from dept t where t.deptno='10';
--minus 差集:显示2个查询语句结果不同的内容
select * from dept
minus
select * from dept t where t.deptno='10';
--intersect 交集:只显示2个查询语句结果相同的内容
select * from dept
intersect
select * from dept t where t.deptno='10'
07-oracle多表查询的更多相关文章
- oracle系统表查询
oracle查询用户下的所有表 select * from all_tab_comments -- 查询所有用户的表,视图等select * from user_tab_comments -- 查询本 ...
- Oracle锁表查询和解锁方法
数据库操作语句的分类 DDL:数据库模式定义语言,关键字:create DML:数据操纵语言,关键字:Insert.delete.update DCL:数据库控制语言 ,关键字:grant.remov ...
- oracle锁表查询
ORACLE EBS操作某一个FORM界面,或者后台数据库操作某一个表时发现一直出于"假死"状态,可能是该表被某一用户锁定,导致其他用户无法继续操作 复制代码代码如下: --锁表查 ...
- oracle 字典表查询
1.oracle 字典表查询 /*显示当前用户*/ show user 在sql plus中可用,在pl sql中不可用 /*查看所有用户名*/ select username,user_id,cre ...
- Oracle——多表查询
本次预计讲解的知识点 1. 多表查询的操作.限制.笛卡尔积的问题: 2. 统计函数及分组统计的操作: 3. 子查询的操作,并且结合限定查询.数据排序.多表查询.统计查询一起完成各个复杂查询的操作: 一 ...
- oracle锁表查询,资源占用,连接会话,低效SQL等性能检查
查询oracle用户名,机器名,锁表对象 select l.session_id sid, s.serial#, l.locked_mode, l.oracle_username, l.os_user ...
- Oracle 多表查询(1)
一.基本概念 多表查询的语法如下: SELECT [DISTINCT] * | 字段 [别名] [,字段 [别名] ,…]FROM 表名称 [别名], [表名称 [别名] ,…][WHERE 条件(S ...
- oracle 多表查询
1.注意点 在查询过程中,不确定数据库表中的数据量,先查询数据量,数据量较大,则不能直接查询(select * from emp),如果数据量较大,直接查询容易造成死机或者数据读取较慢,如果较小可以查 ...
- oracle多表查询
多表查询首先要避免笛卡尔集,要避免笛卡尔集,那么查询条件不得少于表的个数-1. 1.显示雇员名,雇员工资以及雇员所在的部门: 2.显示部门号为10的部门名.员工名和工资: 3.显示各个雇员的姓名,工资 ...
- Oracle锁表查询与解锁
锁表查询和解锁 --查询SELECT object_name, machine, s.sid, s.serial# FROM gv$locked_object l, dba_objects o, gv ...
随机推荐
- TextView 垂直居中
需要区分的是这里的top,bottom,ascent,descent,baseline是指字内容的属性,通过getPaint().getFontMetricsInt()来获取得到.和字体内容的外部容 ...
- JW Player开始播放和结束播放事件的捕获
项目中使用到jwPlayer,需要在用户开始播放盒结束播放的时候触发一些事件,所以研究JWPlayer. <script type="text/javascript"> ...
- python字符串字典列表互转
#-*-coding:utf-8-*- #1.字典 dict = {'name': 'Zara', 'age': 7, 'class': 'First'} #字典转为字符串,返回:<type ' ...
- tensorflow使用
近期在工作中使用tensorflow训练神经网络模型,使用方法简要记录. 环境配置
- requirejs 配制
baseUrl: 用来配制动态加载脚本时,脚本文件的起始位置,此属性可以指定值,也可以由 requirejs 自动计算出值: 1:不进行任何配制: 假如 a.html 中引用 require.js 文 ...
- 按照已有的模板输出<一>(如发票)
按照已有的模板输出<一> 普通的发票基本上都是固定模式,所以我们一般写好固定的模板,把其中需要变动的地方,以特定符号来代替.每次打印发票的时候,只需将其中的特定符号转换成我们需要显示的数据 ...
- 使用st link v2向stm32下载和调试程序
st官网 正版ST-link/V2引脚定义和注意事项 分为ST-LINK/V2和ST-LINK/V2-ISOL两种型号 是STM8和STM32微控制器(MCU)系列的在线调试器和编程器(还是下载器.仿 ...
- vs 页面浏览不显示.aspx后缀名
转:http://www.cnblogs.com/hllive/p/6029763.html 由vs2013新建“web窗体应用程序”的网站,URL不显示扩展名.那今天就实现该功能 1.首先打开vs2 ...
- BF、kmp算法
第七周 字符串匹配 BF算法,kmp算法 BF:时间复杂度为 O(m*n) int Index_BF(SString S, SString T, int pos) { ; while (i <= ...
- 二十三、MongoDb 数据库介绍、安装、启动和连接(非关系型数据库)
1.数据库和文件的主要区别 1. 数据库有数据库表.行和列的概念,让我们存储操作数据更方便2. 数据库提供了非常方便的接口,可以让 nodejs.php java .net 很方便的实现增加修改删除功 ...