Oracle中的left join、right join、inner join

来源:互联网 发布:浏览器代理软件 编辑:程序博客网 时间:2024/06/05 16:39
数据表的连接有:
1、内连接(自然连接): 只有两个表相匹配的行才能在结果集中出现
2、外连接: 包括
(1)左外连接 (左边的表不加限制)
(2)右外连接(右边的表不加限制)
(3)全外连接(左右两表都不加限制)
3、自连接(连接发生在一 张基表内)

sql标准语法:
select table1.column,table2.column
from table1 [inner | left | right | full ] join table2 on table1.column1 = table2.column2;

inner join 表示内连接;left join表示左外连接;right join表示右外连接;full join表示完全外连接;
on子句用于指定连接条件。注意,如果使用from子句指定内、外连接,则必须要使用on子句指定连接条件;
如果使用(+)操作符指定外连接,则必须使用where子句指定连接条件。

如果主表的主键列和从表的外部键列名称相同,那么可以使用 natural join 关键字自动执行内连接操作。
select  dname,ename from dept natural join emp;


select a.studentno, a.studentname, b.classname
from students a, classes b
where a.classid(+) = b.classid;
STUDENTNO STUDENTNAM CLASSNAME
---------- ---------- ------------------------------
1                       周虎                 一年级一班
2                       周林                 一年级二班
                                                 一年级三班
以上语句是右连接:
即"(+)"所在位置的另一侧为连接的方向,右连接说明 等号右侧的所有
记录均会被显示,无论其在左侧是否得到匹配。也就是说上例中,无
论会不会出现某个班级没有一个学生的情况,这个班级的 名字都会在
查询结构中出现。
反之:
select a.studentno, a.studentname, b.classname
from students a, classes b
where a.classid = b.classid(+);
STUDENTNO STUDENTNAM CLASSNAME
---------- ---------- ------------------------------
1                    周虎                     一年级一班
2                    周林                     一年级二班
3                   钟林达
则是左连接,无论这个学生有没有一个能在一个班级中得到匹配的部门号,
这 个学生的记录都会被显示。
select a.studentno, a.studentname, b.classname
from students a, classes b
where a.classid = b.classid;
这个则是通常 用到的内连接,显示两表都符合条件的记录
总之,
左连接显示左边全部的和右边与左边相同的
右连接显示右边全部的和左边与右边 相同的
内连接是只显示满足条件的! ......

----------------------------------------------------------------
补充:
使用(+)的注意事项:
1.(+)操作符只能出现在where子句中,并且不能与outer join语法同时使用。
2.当使用(+)操作符执行外连接时,如果在where子句中包含有多个条件,则必须在所有条件中都包含(+)操作符。
3.(+)操作符只适用于列,而不能用在表达式上。
4.(+)操作符不能与or和in操作符一起使用。
5.(+)操作符只能用于实现左外连接和右外连接,而不能用于实现完全外连接。
for example:

select a.dname,b.ename from dept a,emp b where a.deptno = b.deptno(+) and b.deptno(+) = 10;

*******************************************************************

一、外连接1.概念:包括左向外联接、右向外联接或完整外部联接

2.左连接:leftjoinleftouterjoin

(1)左向外联接的结果集包括LEFTOUTER 子句中指定的左表的所有行,而不仅仅是联接列所匹配的行。如果左表的某行在右表中没有匹配行,则在相关联的结果集行中右表的所有选择列表列均为空值(null)。

(2)sql语句select*from table1leftjoin table2on table1.id=table2.id

-------------结果

-------------idnameidscore------------------------------

1lee1902

zhang21004

wangNULLNULL------------------------------

注释:包含table1的所有子句,根据指定条件返回table2相应的字段,不符合的以null显示

3.右连接:rightjoinrightouterjoin(

1)右向外联接是左向外联接的反向联接。将返回右表的所有行。如果右表的某行在左表中没有匹配行,则将为左表返回空值。

(2)sql语句select*from table1rightjoin table2on table1.id=table2.id

-------------结果-------------

idnameidscore

------------------------------

1lee1902

zhang2100

NULLNULL370

------------------------------

注释:包含table2的所有子句,根据指定条件返回table1相应的字段,不符合的以null显示

4.完整外部联接:fulljoinfullouterjoin

(1)完整外部联接返回左表和右表中的所有行。当某行在另一个表中没有匹配行时,则另一个表的选择列表列包含空值。如果表之间有匹配行,则整个结果集行包含基表的数据值。

(2)sql语句select*from table1fulljoin table2on table1.id=table2.id

-------------结果-------------

idnameidscore------------------------------

1lee1902

zhang21004

wangNULLNULL

NULLNULL370

------------------------------

注释:返回左右连接的和(见上左、右连接)二、内连接

1.概念:内联接是用比较运算符比较要联接列的值的联接

2.内连接:joininnerjoin3.sql语句select*from table1join table2on table1.id=table2.id

-------------结果-------------

idnameidscore

------------------------------

1lee1902zhang2100

------------------------------

注释:只返回符合条件的table1和table2的列

4.等价(与下列执行效果相同)

A:select a.*,b.*from table1 a,table2 bwhere a.id=b.id

B:select*from table1crossjoin table2where table1.id=table2.id (注:cross join后加条件只能用where,不能用on)

三、交叉连接(完全)

1.概念:没有WHERE 子句的交叉联接将产生联接所涉及的表的笛卡尔积。

第一个表的行数乘以第二个表的行数等于笛卡尔积结果集的大小。

(table1和table2交叉连接产生3*3=9条记录)

2.交叉连接:crossjoin (不带条件where...)

3.sql语句select*from table1crossjoin table2

-------------结果-------------

idnameidscore------------------------------

1lee1902

zhang1904

wang1901l

ee21002

zhang21004

wang21001l

ee3702

zhang3704

wang370

------------------------------

注释:返回3*3=9条记录,即笛卡尔积4.等价(与下列执行效果相同)

A:select*from table1,table2