Oracle数据库里查询有个表的自连接,请问这个自连接的用途,使用条件?
2个回答
展开全部
自然连接(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里面查找,从而找到上级领导的名字
比如 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里面查找,从而找到上级领导的名字
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询