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.左连接:leftjoin 或leftouterjoin
(1)左向外联接的结果集包括LEFTOUTER 子句中指定的左表的所有行,而不仅仅是联接列所匹配的行。如果左表的某行在右表中没有匹配行,则在相关联的结果集行中右表的所有选择列表列均为空值(null)。
(2)sql语句select*from table1leftjoin table2on table1.id=table2.id
-------------结果
-------------idnameidscore------------------------------
1lee1902
zhang21004
wangNULLNULL------------------------------
注释:包含table1的所有子句,根据指定条件返回table2相应的字段,不符合的以null显示
3.右连接:rightjoin 或rightouterjoin(
1)右向外联接是左向外联接的反向联接。将返回右表的所有行。如果右表的某行在左表中没有匹配行,则将为左表返回空值。
(2)sql语句select*from table1rightjoin table2on table1.id=table2.id
-------------结果-------------
idnameidscore
------------------------------
1lee1902
zhang2100
NULLNULL370
------------------------------
注释:包含table2的所有子句,根据指定条件返回table1相应的字段,不符合的以null显示
4.完整外部联接:fulljoin 或fullouterjoin
(1)完整外部联接返回左表和右表中的所有行。当某行在另一个表中没有匹配行时,则另一个表的选择列表列包含空值。如果表之间有匹配行,则整个结果集行包含基表的数据值。
(2)sql语句select*from table1fulljoin table2on table1.id=table2.id
-------------结果-------------
idnameidscore------------------------------
1lee1902
zhang21004
wangNULLNULL
NULLNULL370
------------------------------
注释:返回左右连接的和(见上左、右连接)二、内连接
1.概念:内联接是用比较运算符比较要联接列的值的联接
2.内连接:join 或 innerjoin3.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
- Oracle中的left join、right join、inner join
- Oracle中的left join、right join、inner join
- Oracle中的left join,right join和inner join
- oracle join、inner join、left join、right join、full join
- Oracle之left join,right join,inner join,full join
- Oracle 连表查询 inner join;left join; right join!
- Oracle中join left,join right,inner join
- Oracle中join left,join right,inner join
- Oracle inner join、left join、right join的联接查询
- oracle中left join,right join,inner join用法
- ORACLE的left join、right join和inner join详解
- Oracle中left join,right join,inner join分析
- sql中的left join、right join、inner join
- mysql中的inner join,left join,right join
- inner/left/right join
- left join /right join/inner join区别
- mysql left join right join inner join
- left join/right join/inner join
- nginx配置安装之-修改nginx版本号
- listview小例子
- 各大搜索引擎的比较
- MongoDB 如此简单高效
- 自定义类型的思考
- Oracle中的left join、right join、inner join
- 函数
- Vaadin Web应用开发教程(33):UI布局-HorizontalSplitPanel和VerticalSplitPanel布局
- Android ApiDemos示例解析(142):Views->Layouts->LinearLayout->2. Vertical (Fill Screen)
- 由近期裁员想到的
- Hibernate的一对多XML映射教程
- PID为0的系统空闲进程连接状态为TIME_WAIT
- Drop unused columns --1
- ooj 1664