表的连接(一)

来源:互联网 发布:魔方软件官方下载 编辑:程序博客网 时间:2024/06/01 09:42
 表的连接:
1、等值连接(简单连接或内部连接):是在WHERE子句中使用等号。等值连接通常被称为简单连接或内部连接。
select a.x,b.x from tableA a,tableB b where a.id=b.id;
通常,根据给定的条件返回行数最少的表会作为驱动表--也就是基表。
不等值联合:是在WHERE子句中使用除了等号以外的其它比较运算符。
2、外部连接
外部连接的运算符是用括号括起来的加号(+)。语法:
select t1.column,t2.column from table t1,table2 t2
where t1.column(+)=t2.column;

select t1.column,t2.column from table t1,table2 t2
where t1.column=t2.column(+);
外部连接注意事项:
(1)外部连接运算符只能放在连接条件表达式的一侧,即缺少相关连接信息的表一侧。它能返回该表中那些在另一个表中没有得到匹配的记录。
3、自身连接
--自身连接,查询每位雇员的上级主管
select e.ename||' works for '||m.ename
from emp e,emp m
where e.mgr=m.empno
4、SQL:1999语法的连接
在查询中使用SQL:1999语法可以达到和前面所介绍的方法同样的效果。
(1)交叉连接:
CROSS JOIN 子句会产生两个表的交叉乘积,和两个表之间的笛卡尔积是一样的。
(2)自然连接
NATURAL JOIN 使用所有名称和数据类型相匹配的列连接两个表
使用NATURAL JOIN关键字可以实现具有列名和数据类型相匹配的两个表之间的自动连接。
使用自然连接时应注意以下事项:
a、自然连接子句是基于两个表存在相同名字的列。
b、返回两个表相匹配列中具有相同值的记录。
c、如果相同名称的列的数据类型不同,则会产生错误。
例子:
--自然连接,EMP表和DEPT表的自然连接
select empno,ename,sal,deptno,loc
from emp
natural join dept
where deptno in(20,30);
原创粉丝点击