MySQL的内部联结,外部联结和自然联结

一、SELECT语句
一个典型的SQL查询语句具有如下形式:

  
  
  1. SELECT A1,A2, ... ,An
  2. FROM r1, r2, ... ,rm
  3. WHERE P;
select子句列出查询结果中所需要的属性。
from子句是一个查询求值中需要访问的关系列表。
where子句是一个作用在from子句关系属性上的谓词。

其中from这个子句定义的是一个在该子句中列出的关系上的笛卡尔积。可以用如下表述:

  
  
  1. for each 元组t1 in 关系r1
  2. for each 元组t2 in 关系r2
  3. ...
  4. 把t1, t2, ..., 连接成单个元组t
  5. 把t加入到结果关系中
举个例子,我这里有表1:Name


表2:Address

测试FROM语句,会产生如下的笛卡尔积:


二、内部联结
内部联结又称为等值联结,将两个表中存在联结关系的字段符合联结关系的那些记录形成记录集的联结。用INNER JOIN 指定表之间的关系,用ON子句指定联结条件。
首先看看不加联结条件的内部联结:

这个结果和select * from Name, Address一样。

再加上联结条件:Name.id = Address.id

其结果就是显式id相等的部分。

这个其实和语句SELECT WHERE一样的,来看下面的结果:

三、自然联结
自然联结其实和内部联结一样,只是不会出现相同的重复列。比如在上边的INNER JOIN中,出现了两个id列,他们一模一样。
在以前的版本中,有natural join 来实现自然联结,也就是去除重复的列。在最新版本的MySQL中,不在支持natural join。把这项工作交给了用户。
如果我们想得到不重复的列,可以这样做:

四、外部联结
外部联结中包含了在相关表中没有关联的行。举个例子,我在Name表中再插入一行,这一行在Address表中没有对应的id记录这个人的地址。

如果我们使用内部联结,就不会出现"Fox"这个人的信息。


但是我想显示所有人的信息,不管他们有没有地址。这就可以使用外部联结。
外部联结分为LEFT OUTER JOIN 和RIGHT OUTER JOIN。比如我这里使用LEFT OUTER JOIN:

上边的语句使用了LEFT OUTER JOIN。它以左边的表(也就是Name)作为基准,会选择Name中的所有行,如果该行在Address表中不存在相应的记录,就会以null值(必须要支持null值)显示。

同理,RIGHT OUTER JOIN 是以右边的表作为基准。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值