Oracle数据库里查询有个表的自连接,请问这个自连接的用途,使用条件?

查询里的(表的自连接)使用环境是什么样的,在什么时候能用到?语句怎么写?... 查询里的(表的自连接)使用环境是什么样的,在什么时候能用到?语句怎么写? 展开
 我来答
End灬琦琦
2011-11-07 · TA获得超过956个赞
知道小有建树答主
回答量:181
采纳率:0%
帮助的人:196万
展开全部
自然连接(natural join)是在两张表中寻找那些数据类型跟列明相同的字段,然后自动的将他们连接起来,并返回所有符合条件的结果
比如 select id,name from dave a natural join b1 b;
结果 ID Name
1 dave
2 b1
这里我们并没有指定连接的条件,实际上oracle为我们自作主张的将dave表中的id和name字段与b1表中的id和name字段进行了连接,也就是实际上相当于
select dave.id,b1.name from dave join b1 on dave.id=b1.id and dave.name=b1.name;
因此,我们也可以将自然连接理解为内连接的一种。
有关自然连接的一些注意事项:
(1)如果做自然连接的两个表的有多个阻断满足有相同名称的类型,那么他们会被作为自然连接的条件
(2)如果自然连接的2个表字段相同,但是数据类型不容,那么将会返回一个错误。
-----------------------------------sorry,看到楼下回答,及时更正-------------------------------
自连接的例子:
select a1.names as employee_name,a2.names as manager_name
from table_a as a1, table_a as a2
where a1.manage_id=a2.employee_id;
上述语句,是查询,领导与下属。
以雇员id为一个连接,通过上级的id在雇员id里面查找,从而找到上级领导的名字
wang5622569
2011-10-27 · TA获得超过104个赞
知道答主
回答量:150
采纳率:0%
帮助的人:105万
展开全部
自连接和自然连接不是一回事 楼上的傻了....
自连接是一个表内根据一些condition自己跟自己连接
自然连接是两个表之间的连接
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式