多表联合查询:需要获取的数据分布在多张表中

SQL92:

 --笛卡尔积:将多个表的数据进行一一对应,所得的结果为多表的笛卡尔积
select * from emp;
select * from dept;
select * from emp,dept;--进行全排列 14*5=70

 --等值连接:先笛卡尔积,然后筛选,筛选条件为等值筛选
--查询员工的姓名,工作,薪资,部门名称
--可直接在select子句中使用字段获取数据,但效率低,建议字段前明确表名
select ename,job,sal,dname from emp,dept where emp.deptno=dept.deptno;--效率低
--两张表存在的公众字段,必须明确表名:emp.deptno=dept.deptno
select emp.ename,emp.job,emp.sal,dept.dname from emp,dept where emp.deptno=dept.deptno;--效率高
--给表添加别名(推荐)
select e.ename,e.job,e.sal,d.dname
from emp e,dept d
where e.deptno=d.deptno;

 --查询员工的姓名,工作,工资,工资等级
select e.ename,e.job,e.sal,s.grade
from emp e,salgrade s
where e.sal>=s.losal and e.sal<=s.hisal;

 --自连接
--查询员工的姓名,工作,薪资,及上级领导的姓名
select e1.ename,e1.job,e1.sal,e2.ename
from emp e1,emp e2
where e1.mgr=e2.empno;
----------------下面SQL可详细查看到对应的领导姓名详情-------------------
select e1.empno,e1.ename,e1.job,e1.sal,e1.mgr,e2.ename
from emp e1,emp e2
where e1.mgr=e2.empno;

外连接:左外连接&&右外连接

 --左外链接
--查询员工的姓名,工作,薪资,部门名称及没有部门的员工信息(删除SMITH的部门编号测试)
select e.ename,e.job,e.sal,d.dname
from emp e,dept d
where e.deptno=d.deptno(+);

 --右外连接
--查询员工的姓名,工作,薪资,部门名称及没有员工的部门信息
select e.ename,e.job,e.sal,d.dname
from emp e,dept d
where e.deptno(+)=d.deptno;

SQL99:
1:可给表添加别名
2:如果使用on或者usering关键字对结果进行筛选,必须使用inner join作为表与表的连接,其中inner可缺省
3:外连接的outer可缺省
4:依然可以使用分组,having,排序等。

 --笛卡尔积:使用关键字 cross join
--select * from 表名1 cross join 表名2;
select * from emp cross join dept;

 --筛选
--自然连接:使用关键字 natural join
--特点1:底层先笛卡尔积,然后按照所有同名同值字段自动进行等值筛选
--查询员工的姓名,工作,薪资,部门名称
select e.ename,e.job,e.sal,d.dname from emp e natural join dept d;

问题1:如果只想按照部分字段结束筛选?
解决1:使用using关键字
作用1:指明使用指定的字段对联合查询的结果进行等值筛选
注意1:指明字段必须是两表的同名同值字段
使用:select * from 表名 inner join 表名 using(字段名1,字段名2...);

 --查询员工的姓名,工作,薪资,部门名称
select emp.ename,emp.job,emp.sal,dept.dname
from emp
inner join dept using(deptno);

问题2:如果按照字段名不同,但是值相同进行等值筛选?
解决2:使用on关键字进行自定义条件筛选(等值,不等值)
注意1:普通筛选条件使用where进行筛选,不要使用on。(增加SQL语句的阅读性)
使用:select 内容 from 表名 inner join 表名 on 连接条件 where 普通筛选条件;

 --查询员工的姓名,工作,薪资,部门名称并工资大于等于2000
select emp.ename,emp.job,emp.sal,dept.dname
from emp
inner join dept
on emp.deptno=dept.deptno where sal>=2000;

外链接
--左外连接:select 内容 from 表名 left outer join 表名 on 连接条件

 --查询员工的姓名,工作,薪资,部门名称及没有部门的员工信息(删除SMITH的部门编号测试)
select e.ename,e.job,e.sal,d.dname
from emp e
left outer join dept d
on e.deptno=d.deptno;


--右外连接:select 内容 from 表名 right outer join 表名 on 连接条件

 --查询员工的姓名,工作,薪资,部门名称及没有员工的部门信息
select e.ename,e.job,e.sal,d.dname
from emp e
right outer join dept d
on e.deptno=d.deptno;
 --全外连接:select 内容 from 表名 full outer join 表名 on 连接条件
select e.ename,e.job,e.sal,d.dname
from emp e
full outer join dept d
on e.deptno=d.deptno;
 --自链接:
--查询员工的姓名,工作,薪资,及上级领导的姓名
select e1.ename,e1.job,e1.sal,e2.ename
from emp e1
inner join emp e2
on e1.mgr=e2.empno;

SQL92 && SQL99 详细比对:

 -------------------------------------------------- SQL92 && SQL99 详细比对 --------------------------------------------------
--SQL92
--笛卡尔积
select * from emp,dept;--进行全排列
--SQL99
--笛卡尔积:使用关键字 cross join
select * from emp cross join dept; --SQL92
--等值连接
--查询员工的姓名,工作,薪资,部门名称
select e.ename,e.job,e.sal,d.dname
from emp e,dept d
where e.deptno=d.deptno;
--SQL99
--自然连接:使用关键字 natural join
--查询员工的姓名,工作,薪资,部门名称
select e.ename,e.job,e.sal,d.dname
from emp e
natural join dept d;
--查询员工的姓名,工作,薪资,部门名称
select emp.ename,emp.job,emp.sal,dept.dname
from emp
inner join dept using(deptno); --SQL92
--不等值连接
--查询员工的姓名,工作,工资,工资等级
select e.ename,e.job,e.sal,s.grade
from emp e,salgrade s
where e.sal>=s.losal and e.sal<=s.hisal;
--SQL99
--查询员工的姓名,工作,工资,工资等级
select e.ename,e.job,e.sal,s.grade
from emp e
natural join salgrade s
where e.sal>=s.losal and e.sal<=s.hisal; --SQL92
--自连接
--查询员工的姓名,工作,薪资,及上级领导的姓名
select e1.ename,e1.job,e1.sal,e2.ename
from emp e1,emp e2
where e1.mgr=e2.empno;
--SQL99
--查询员工的姓名,工作,薪资,及上级领导的姓名
select e1.ename,e1.job,e1.sal,e2.ename
from emp e1
inner join emp e2
on e1.mgr=e2.empno; --SQL92
--左外链接
--查询员工的姓名,工作,薪资,部门名称及没有部门的员工信息(删除SMITH的部门编号测试)
select e.ename,e.job,e.sal,d.dname
from emp e,dept d
where e.deptno=d.deptno(+);
--SQL99
select e.ename,e.job,e.sal,d.dname
from emp e
left outer join dept d
on e.deptno=d.deptno --SQL92
--右外连接
--查询员工的姓名,工作,薪资,部门名称及没有员工的部门信息
select e.ename,e.job,e.sal,d.dname
from emp e,dept d
where e.deptno(+)=d.deptno;
--SQL99
select e.ename,e.job,e.sal,d.dname
from emp e
right outer join dept d
on e.deptno=d.deptno; --SQL99
--全外连接:select 内容 from 表名 full outer join 表名 on 连接条件
select e.ename,e.job,e.sal,d.dname
from emp e
full outer join dept d
on e.deptno=d.deptno;

SQL92 && SQL99 详细比对

Oracle【多表查询操作(SQL92&SQL99)】的更多相关文章

  1. Oracle锁表查询和解锁方法

    数据库操作语句的分类 DDL:数据库模式定义语言,关键字:create DML:数据操纵语言,关键字:Insert.delete.update DCL:数据库控制语言 ,关键字:grant.remov ...

  2. oracle锁表查询

    ORACLE EBS操作某一个FORM界面,或者后台数据库操作某一个表时发现一直出于"假死"状态,可能是该表被某一用户锁定,导致其他用户无法继续操作 复制代码代码如下: --锁表查 ...

  3. MySQL/MariaDB数据库的多表查询操作

    MySQL/MariaDB数据库的多表查询操作 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.单表查询小试牛刀 [root@node105.yinzhengjie.org.cn ...

  4. oracle系统表查询

    oracle查询用户下的所有表 select * from all_tab_comments -- 查询所有用户的表,视图等select * from user_tab_comments -- 查询本 ...

  5. 在MyBatis中查询数据、涉及多参数的数据访问操作、插入数据时获取数据自增长的id、关联表查询操作、动态SQL、关于配置MyBatis映射没有代码提示的解决方案

    1. 单元测试 在单元测试中,每个测试方法都需要执行相同的前置代码和后置代码,则可以自定义2个方法,分别在这2个方法中执行前置代码和后置代码,并为这2个方法添加@Before和@After注解,然后, ...

  6. oracle 字典表查询

    1.oracle 字典表查询 /*显示当前用户*/ show user 在sql plus中可用,在pl sql中不可用 /*查看所有用户名*/ select username,user_id,cre ...

  7. Oracle——多表查询

    本次预计讲解的知识点 1. 多表查询的操作.限制.笛卡尔积的问题: 2. 统计函数及分组统计的操作: 3. 子查询的操作,并且结合限定查询.数据排序.多表查询.统计查询一起完成各个复杂查询的操作: 一 ...

  8. oracle锁表查询,资源占用,连接会话,低效SQL等性能检查

    查询oracle用户名,机器名,锁表对象 select l.session_id sid, s.serial#, l.locked_mode, l.oracle_username, l.os_user ...

  9. Oracle 多表查询(1)

    一.基本概念 多表查询的语法如下: SELECT [DISTINCT] * | 字段 [别名] [,字段 [别名] ,…]FROM 表名称 [别名], [表名称 [别名] ,…][WHERE 条件(S ...

随机推荐

  1. 星际争霸,FF反作弊对战平台

    星际一 [FF]反作弊对战平台让作弊行为无所遁形,只为星际玩家服务的反作弊对战平台目前能检查星际霸主以及其他星际争霸ZUOBI软件支持星际113版本 支持XP WIN7 WIN8 MAC 游戏外挂带来 ...

  2. 【JVM学习笔记】系统类加载器

    可以通过“java.system.class.loader"属性指定系统类加载器 默认情况下,该属性值为空: public class Test { public static void m ...

  3. JavaScript(6)—— 返回特征数字

    案例要求 根据业务情况,要把核心的东西变成一个模块便于复用,慢慢沉淀后,能够更快更高效地编程. 业务核心算法: /* 数字检测 @return 返回2,能被3和7整除 返回1,能够被3整除 返回0,不 ...

  4. Mac下配置多个SSH Keys

    Mac下配置多个SSH Keys 生成SSH key # Creates a new ssh key using the provided email # 默认生成的文件名为id_rsa,可以根据命令 ...

  5. python基础知识(集合)

    集合 可变集合set()/不可变集合frozenset() {}  大写的拉丁字母 用于保存不重复元素.无序不能通过索引来获取 集合的创建 空集合 使用set()函数 变量名 = set() 集合的添 ...

  6. 解决使用wamp怎么使用php命令行

    用了wamp,把php加到环境变量就报错啊! 那怎么用命令行啊! 可以找么着:(比如想执行 php think build --module demo) E:\php-project\tp5.> ...

  7. 腾讯云远程连接Kafka

    腾讯云服务器上部署Kafka,使用server.properties中公网IP配置: 启动时候报错: ERROR [KafkaServer id=0] Fatal error during Kafka ...

  8. SQL SERVER DATEADD函数

    定义: DATEADD() 函数在日期中加上指定的时间间隔. ※指定的时间间隔可以为负数 语法: DATEADD(datepart,number,date) 参数: ①datepart 参数可以是下列 ...

  9. Oracle - 函数及多表关联

    函数一般是在数据上执行的,它给数据的转换和处理提供了方便.只是将取出的数据进行处理,不会改变数据库中的值.函数根据处理的数据分为单行函数和聚合函数(组函数),组函数又被称作聚合函数,用于对多行数据进行 ...

  10. 小记--------spark的Master的Application注册机制源码分析及Master的注册机制原理分析

    原理图解: Master类位置所在:spark-core_2.11-2.1.0.jar的org.apache.spark.deploy.master下的Master类   //截取了部分代码 //处理 ...