UNION ALL、左右外连接、全外连接、内连接

一、UNION ALL

union操作符合并的结果集,不会允许重复值,如果允许有重复值的话,使用UNION ALL.
直接来个例子UNION ALL、左右外连接、全外连接、内连接

二、左外连接(Left outer join/ left join)
left join是以左表的记录为基础的,例如以a表为基础表,b可以看成右表,它的结果集是a表中的数据,在加上a表和b表匹配的数据。左表a的记录将会全部表示出来,而右表b只会显示符合搜索条件的记录。b表无匹配的地方均为NULL.
select a.ZCBH ZCBH,a.ZCMC ZCMC,b.TDBH TDBH
from ASS_TD_ZCXX a
left join
ASS_FW_ZCMJXX b
on a.ZCBH = b.TDBH
+ 表示补充,即哪个表有加号,这个表就是匹配表。左外连接,左表要全部显示,所以加号写在右表,用(+) 就要用关键字where
select a.ZCBH ZCBH,a.ZCMC ZCMC,b.TDBH TDBH
from ASS_TD_ZCXX a ,ASS_FW_ZCMJXX b
where a.ZCBH = b.TDBH(+)

UNION ALL、左右外连接、全外连接、内连接
三、右外连接(right outer join/ right join)

是以右表为基础的, 显示右表的所有记录,在加上右表和左表匹配的结果。 左表不足的地方用NULL填充.
select b.ZCBH ZCBH,b.JZWMC ZCMC,b.TDBH TDBH
from ASS_TD_ZCXX a
right join
ASS_FW_ZCMJXX b
on a.ZCBH = b.TDBH

UNION ALL、左右外连接、全外连接、内连接

UNION ALL、左右外连接、全外连接、内连接
四、全外连接(full outer join/ full join)
左表和右表都不做限制,所有的记录都显示,两表不足的地方用NULL 填充。 全外连接不支持(+)。
select b.ZCBH ZCBH,b.JZWMC ZCMC,b.TDBH TDBH
from ASS_TD_ZCXX a
full join
ASS_FW_ZCMJXX b
on a.ZCBH = b.TDBH

五、内连接(inner   join)

根据每个表共有的列的值匹配两个表中的行

select b.ZCBH ZCBH,b.JZWMC ZCMC,b.TDBH TDBH
from ASS_TD_ZCXX a
inner join
ASS_FW_ZCMJXX b
on a.ZCBH = b.TDBH

UNION ALL、左右外连接、全外连接、内连接