表的连接(一)

 表的连接:
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);
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值