码迷,mamicode.com
首页 > 数据库 > 详细

数据库连接之内连接、自然连接、外连接区分

时间:2015-07-26 19:24:18      阅读:187      评论:0      收藏:0      [点我收藏+]

标签:

数据库中的连接分为:内连接、自然连接、外连接;(外连接又分为:左外连接,右外连接和全外连接)

自然连接(natural join):

  自然连接是一种特殊的等值连接,他要求两个关系表中进行比较的必须是相同的属性列,无须添加连接条件,并且在结果中消除重复的属性列。

内连接(inner  join):

  指连接结果仅包含符合连接条件的行,参与连接的两个表都应该符合连接条件。

 (内连接基本与自然连接相同,不同之处在于自然连接要求是同名属性列的比较,而内连接则不要求两属性列同名,可以用on来指定某两列字段相同的连接条件) 

自然连接,内连接时某些属性值不同则会导致这些元组会被舍弃,那如何保存这些会被丢失的信息呢,外连接就解决了相应的问题。

外连接:

  连接结果不仅包含符合连接条件的行同时也包含自身不符合条件的行。包括左外连接、右外连接和全外连接。

左外连接:

  左边表数据行全部保留,右边表保留符合连接条件的行

右外连接:

  右边表数据行全部保留,左边表保留符合连接条件的行

全外连接:

  左外连接 union右外连接

例子:

表TESTA,TESTC,TESTD各有A, B两列

TESTB有A,C两列


技术分享

首先做个全表查询(笛卡尔积) 
SELECT * FROM TESTA,TESTB;

技术分享

一、自然连接

SELECT * FROM TESTA NATURAL JOIN TESTB;

技术分享

二、内连接:这边我们演示的是等值连接

方式一:SELECT * FROM TESTA a ,TESTC c WHERE a.A=c.A;

方式二:SELECT * FROM TESTA a INNER JOIN TESTC c ON (a.A=c.A);

结果表如下:

技术分享

三、外连接:

1.左外连接 left outer join 或者 left join

左外连接就是在等值连接的基础上加上主表中的未匹配数据,例: 

写法一:SELECT * FROM TESTA a LEFT OUTER JOIN TESTC c ON (a.A=c.A);

写法二:SELECT * FROM TESTA a LEFT JOIN TESTC c ON (a.A=c.A);

ORACLE特有写法:SELECT * FROM TESTA a,TESTC c WHERE a.A=c.A(+);

结果表如下:

技术分享

2.右外连接 right outer join 或者 right join

右外连接是在等值连接的基础上加上被连接表的不匹配数据 

写法一:SELECT * FROM TESTA a RIGHT OUTER JOIN TESTC c ON (a.A=c.A);

写法二:SELECT * FROM TESTA a RIGHT JOIN TESTC c ON (a.A=c.A);

ORACLE特有写法:SELECT * FROM TESTA a,TESTC c WHERE a.A(+)=c.A;

结果表如下:

技术分享

3.全外连接 full outer join 或者 full join

全外连接是在等值连接的基础上将左表和右表的未匹配数据都加上 

写法一:SELECT * FROM TESTA a FUll OUTER JOIN TESTC c ON (a.A=c.A);

写法二:SELECT * FROM TESTA a FUll  JOIN TESTC c ON (a.A=c.A);

等价写法:

SELECT * FROM TESTA a LEFT JOIN TESTC c ON (a.A=c.A)

UNION

SELECT * FROM TESTA a RIGHT JOIN TESTC c ON (a.A=c.A);

结果表如下:

技术分享

技术分享

数据库连接之内连接、自然连接、外连接区分

标签:

原文地址:http://my.oschina.net/nyp/blog/483891

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!