Oracle 数据库基础学习 (五) 多表查询

时间:2022-07-06 14:28:06

多表查询:查询结果需要用到两个或者以上表,此时需要多表连接,产生多表查询

1、内连接(等值连接)

示例:将两个表内容连接显示

select * from dept d, emp e where d.deptno = e.deptno;

注意:只有当d.deptno = e.deptno条件满足,内容才会显示,否则不显示

2 、外连接:让等值判断左右两边有一边的数据可以全部显示出来,使用外连接方式时使用”(+)”

格式:  

左外连接:字段=字段(+)

右外连接:字段(+)=字段

示例:显示雇员的姓名,职位和领导姓名

分析:

确认要使用的数据:

1、  emp表的雇员姓名,职位(别名为e)

2、  emp表的领导姓名(别名为m)

确认相连的关系:

e.mgr = m.empno;

如果某个雇员没有领导的时候,其内容将会显示不出来,此时需要用外连接,让其中一边的表在没有领导的情况下,也可以显示出来。

左、右外连接可以不区分,但是最重要的是把要显示的内容显示出来就行。

select e.ename, e.job, m.ename
from emp e, emp m
where e.mgr = m.empno(+);