关闭

oracle 左右内和完全链接

489人阅读 评论(2) 收藏 举报
分类:


数据表的连接有: 
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、外连接: 包括 
(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、外连接: 包括 
(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、外连接: 包括 
(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、外连接: 包括 
(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、外连接: 包括 
(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、外连接: 包括 
(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、外连接: 包括 
(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、外连接: 包括 
(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、外连接: 包括 
(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、外连接: 包括 
(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、外连接: 包括 
(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、外连接: 包括 
(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、外连接: 包括 
(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、外连接: 包括 
(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、外连接: 包括 
(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、外连接: 包括 
(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、外连接: 包括 
(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、外连接: 包括 
(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、外连接: 包括 
(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、外连接: 包括 
(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、外连接: 包括 
(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、外连接: 包括 
(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、外连接: 包括 
(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、外连接: 包括 
(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、外连接: 包括 
(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、外连接: 包括 
(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
1
查看评论

【Oracle】多表连接查询——内连接、左连接、右连接、全连接(外连接)、完全连接

--内连接说明:查询表A, 表B中所有符合WHERE条件的结果范例:SELECT A.ETM_ENTY_SUB_TYPE_INDC, B.EYD_ENTY_SRNO  FROM TRDX_ENTITY_TYPE_MASTER A, TRDX_ENTITY_TYPE_DTLS B ...
  • amber_xiaoya
  • amber_xiaoya
  • 2010-07-12 11:23
  • 15298

Oracle内连接、左外连接、右外连接、全外连接

表TESTA,TESTB,TESTC,各有A, B两列 A B 001 10A 002 20A A B 001 10B 003 30B A B 001
  • futdktyx
  • futdktyx
  • 2013-12-06 13:46
  • 1651

mysql的内链接和左右连接的区别

1.内连接 mysql中内连接的数据记录中,不存在字段为null的情况,可以简单的认为,内连接就是左连接或者右连接的结果中剔除所有字段为null记录后的结果。另外mysql 不支持full join 2.左连接 mysql中左连接就是选择一个主表例如t_user在左侧,并显示所有记录,根据条件显示从...
  • jaryle
  • jaryle
  • 2017-01-04 14:43
  • 767

关联查询 内连接 左右外连接 完全外连接

SQL多表连接查询(详细实例) http://www.xker.com/page/e2012/0708/117368.html 本文主要列举两张和三张表来讲述多表连接查询。 新建两张表: 表1:student  截图如下: 表2:course  截图...
  • yuliangliang092
  • yuliangliang092
  • 2016-04-06 15:36
  • 3995

oracle左外连接、右外连接、完全外连接以及(+)号用法

准备工作 oracle连接分为: 左外连接:左表不加限制,保留左表的数据,匹配右表,右表没有匹配到的行中的列显示为null。右外连接:右表不加限制,保留右表的数据。匹配左表,左表没有匹配到的行中列显示为null。完全外连接:左右表都不加限制。即右外连接的结果为:左右表匹配的数据+左表没有匹配到的...
  • fly_zxy
  • fly_zxy
  • 2016-12-31 11:53
  • 1091

Mysql 内连接、外连接、全连接和交叉连接

为了演示方便,提前准备了两张表department和employees,其中的字段和数据如图所示: department   employees 连接分为:内连接、外连接、交叉连接 一、内连接( 最常用 )     定义:仅将两个表中满足连接条件的行...
  • u013215018
  • u013215018
  • 2016-10-13 18:14
  • 4664

oracle 左右连接,全连接

右连接: SELECT emp_name, dept_name    FORM Employee, Department    WHERE Employee.emp_deptid(+) = Department.deptid此SQL文使用了右连接,即“(+)”所在位置的另一...
  • wyswlp
  • wyswlp
  • 2013-04-04 16:21
  • 9245

oracle的左右链接

总结:   1,(+)在哪一边,则返回另一边所有的记录。 2,(+)放在包含空值的一边,不可以两边同时使用。
  • u012354280
  • u012354280
  • 2013-10-23 21:21
  • 247

ORACLE 左右链接

数据表的连接有: 1、内连接(自然连接): 只有两个表相匹配的行才能在结果集中出现 2、外连接: 包括      (1)左外连接(左边的表不加限制)      (2)右外连接(右边的表不加限制)   ...
  • wym19830218
  • wym19830218
  • 2010-04-19 17:28
  • 754

oracle左连接和有链接以及“(+)”表示的区别

在Oracle PL-SQL中,左连接和右连接以如下方式来实现 查看如下语句: SELECT emp_name, dept_name FORM Employee, Department WHERE Employee.emp_deptid(+) = Department.deptid 此SQL文...
  • identificationofking
  • identificationofking
  • 2013-08-19 23:06
  • 932
    个人资料
    • 访问:480175次
    • 积分:8170
    • 等级:
    • 排名:第2993名
    • 原创:342篇
    • 转载:138篇
    • 译文:4篇
    • 评论:71条
    博客专栏