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 ...
随机推荐
- 【小梅哥SOPC学习笔记】sof与NIOS II的elf固件合并jic得到文件
sof与NIOS II的elf固件合并jic得到文件 注意,本方法已经有更加简便的方法,小梅哥提供相应的脚本文件,可以一键生成所需文件,脚本请前往芯航线FPGA技术支持群获取. 7.1 为什么需要将S ...
- linux 权限机制
系统每个文件都拥有特定的权限,所属用户及所属组,通过这样的机制限制哪些用户.哪些组可以对特定文件进行什么样的操作,一般分为读.写.执行三种权限. 每个进程都是以某个用户的身份运行,所以进程的权限与该用 ...
- linux 磁盘 分区 MBR GPT
磁盘:由许多盘片,机械手臂,磁头和主轴马达所构成的,实际的数据都是写入盘片上面,而读写主要是通过机械手臂可伸展让磁头在盘片(在主轴马达的转动左右下,盘片跟着转动)上面进行读写操作.由于单一盘片写入数据 ...
- Mathcad操作tips:2D绘图
1. 直接输入算式进行绘图(QuickPlot) 2. 先定义函数,再利用函数绘制多个曲线.一张图最多支持16条曲线.留意“,”的用法. 3. 利用空格键和","在现有绘图上增加新 ...
- [转载].NET开发常用的10条实用代码
1.读取操作系统和CLR的版本 OperatingSystem os = System.Environment.OSVersion; Console.WriteLine(“Platform: {0}” ...
- CentOS下Docker与.netcore(一) 之 安装
CentOS下Docker与.netcore(一) 之 安装 CentOS下Docker与.netcore(二) 之 Dockerfile CentOS下Docker与.netcore(三)之 三剑客 ...
- Ajax 如何执行 Response.Redirect
Ajax 直接对服务端的Response.Redirect是不感冒的, 另觅途径, 具体可行办法如下: Web Service 服务端: public WXService() { if (!IsVal ...
- $().click()和$().on('click',function(){})的区别
1. $(选择器).click(fn) 当选中的选择器被点击时触发回调函数fn.只针对与页面已存在的选择器. HTML代码: <!DOCTYPE html> <html lang=& ...
- 二,php的错误处理
php处理错误的三种方式: 简单的die()语句: 自定义错误和错误触发器:错误日志: 1,简单的die()语句 if(!file_exists("aaa.txt")){ die( ...
- mysql索引的应用场景以及如何使用
唯一的是什么? 1. 索引列(字段)的所有值都只能出现一次,即必须唯一 ---------------------------------------------------------------- ...