UNION ALL、左右外连接、全外连接、内连接
一、UNION ALL
union操作符合并的结果集,不会允许重复值,如果允许有重复值的话,使用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(+)
三、右外连接(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


四、全外连接(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