在内连接中,数据库一般会自动选择数据量少的表作为驱动表,然后循环驱动每一条数据,按照on后面的关联字段,和被驱动表进行匹配,进行数据的拼接。
SELECT T1.EMPNO,T1.JOB,T2.DEPTNO,T2.DNAME,T2.LOC
FROM EMP T1 --被驱动表
INNER JOIN DEPT T2--驱动表
ON T1.DEPTNO = T2.DEPTNO
通过部门编号将员工表和部门信息表进行关联连接,得到两表合并之后的数据。
例:查出员工SCOTT所在的部门的部门编号,部门名称和所在地区
---用and过滤
select e.*,t.dname,t.loc
from emp e inner join dept t
on e.deptno=t.deptno
and e.ename = 'SCOTT';
---where过滤
select e.*,t.dname,t.loc
from emp e inner join dept t
on e.deptno=t.deptno
where e.ename = 'SCOTT';
语法:
select 查询字段
from 表1,表2
where 关联字段(此处where相当于 on)
and 过滤条件
注:虽然在隐式写法中,where 相当于 on ,但在隐式写法中不能将两者做等价使用,隐式写法只允许用where 作为两表的关联条件,用on为错误的写法。
---正确写法
select e.*,t.dname,t.loc
from emp e ,dept t
where e.deptno=t.deptno
and e.ename = 'SCOTT'
---错误写法
select e.*,t.dname,t.loc
from emp e ,dept t
on e.deptno=t.deptno --on 错误
and e.ename = 'SCOTT'
SELECT * FROM EMP E cross join DEPT D ; -- cross join 显式交叉连接写法
SELECT * FROM EMP E ,DEPT D ; --隐式交叉连接写法
外连接区别与内连接:
6. 语法结构上,内连接是[INNER] JOIN,左外连接是LEFT [OUTER] JOIN。
7. 结果上,内连接取的是两个表的交集,左外连接取得是主表的所有信息加上从表的信息,主表的数据就算不满足关联条件也可以被查询出来,从表不匹配的显示为空。
8. 主表、从表。按照左连接的语法结构:表1就是主表,表2就是从表。
语法:
SELECT 要查询的字段/列
FROM 表1 ---主表
LEFT JOIN 表2 ---从表,
ON 关联字段
AND 过滤条件;
注:
9. 主表的数据就算不满足关联条件也可以被查询出来,也就是说主表的数据会全部展示
10. 从表数据,匹配的正常展示,不匹配的显示为空。
SELECT *
FROM DEPT D --主表
LEFT JOIN EMP E --从表
ON E.DEPTNO = D.DEPTNO;
语法:
SELECT 要查询的字段/列
FROM 表1 ---从表
RIGHT JOIN 表2 ---主表,
ON 关联字段
AND 过滤条件;
右连接以表 2 为主表,显示表 2 的所有字段内容,不匹配的则显示为null。
SELECT *
FROM EMP E --从表
RIGHT JOIN DEPT D --主表
ON E.DEPTNO = D.DEPTNO;
全外关联 ,没有主从表,两张表互相比较,相同的部分正常显示,不同的部分互相为 NULL。
语法:
SELECT 要查询的字段/列
FROM 表1
FULL JOIN 表2
ON 关联字段
AND 过滤条件;
全外连接- -展示两张表的全部数据
SELECT e.*,t.*
FROM EMP e
FULL JOIN DEPT t
ON e.deptno = t.deptno
SELECT *
FROM emp e,dept f
where e.deptno=f.deptno(+) -- (+)在右边,另一侧的emp表就是主表
--AND 过滤条件; --是表连接完成后的过滤
SELECT *
FROM emp e,dept f
where e.deptno(+)=f.deptno -- (+)在哪一侧,另一侧的dept表就是主表
--AND 过滤条件 --是表连接完成后的过滤
连接查询总结:
内连接自关联 与 外连接自关联的差异。
例:通过上级领导编号进行表自连接关联。
SELECT T1.EMPNO,T2.EMPNO,T2.ENAME--上级领导员工编号,姓名
FROM EMP T1 --取员工的数据
INNER JOIN EMP T2 --取领导数据
ON T1.MGR = T2.EMPNO --用内连接会过滤掉了董事长那条数据
SELECT T1.EMPNO,T2.EMPNO,T2.ENAME--上级领导员工编号,姓名
FROM EMP T1 ---取员工的数据
LEFT JOIN EMP T2 ---取领导数据
ON T1.MGR = T2.EMPNO --改为左连接可得到董事长那条数据
在emp表中共有14条数据,表全并集后,得到28条数据。
SELECT * FROM EMP --注意上下2个SQL结果集字段顺序,数量要保持一致
UNION ALL
SELECT * FROM EMP;
SELECT * FROM EMP
UNION --拼接上下2个SQL结果集,会进行去重排序(默认是升序排序);
SELECT * FROM EMP;
注: 上下2个SQL结果集字段顺序,数量要保持一致
表交集 INTERSECT 会返回两个查询中共有的查询记录
SELECT DEPTNO FROM EMP
INTERSECT
SELECT DEPTNO FROM DEPT;
表补集 也可认为具有减的功能;
--emp表中只有部门(10、20、30),而部门表中有(10、20、30、40),故补集结果为空
SELECT DISTINCT DEPTNO FROM EMP
MINUS
SELECT DEPTNO FROM DEPT;
--dept部门表中只有部门(10、20、30、40),而emp员工表中有(10、20、30),故补集结果为 40
SELECT DEPTNO FROM DEPT
MINUS
SELECT DISTINCT DEPTNO FROM EMP;