[转]MySQL JOIN 多表连接

MySQL JOIN 多表连接

MySQL JOIN 多表连接

除了常用的两个表连接之外,SQL(MySQL) JOIN 语法还支持多表连接。多表连接基本语法如下:

1 ... FROM table1 INNER|LEFT|RIGHT JOIN table2 ON condition INNER|LEFT|RIGHT JOIN table3 ON condition ...

JOIN 多表连接实现了从多个表中获取相关数据,下面是三个原始数据表:

article 文章表:
aidtitlecontentuidtid
1文章1文章1正文内容…11
2文章2文章2正文内容…12
3文章3文章3正文内容…21
5文章5文章5正文内容…41
user 用户表:
uidusernameemail
1adminadmin@5idev.com
2小明xiao@163.com
3Jackjack@gmail.com
type 文章类型表:
tidtypename
1普通文章
2精华文章
3草稿

MySQL INNER JOIN 多表

我们使用 INNER JOIN 列出三个表中都具有关联关系的数据:

1 SELECT article.aid,article.title,user.username,type.typename FROM article INNER JOIN user
2 ON article.uid=user.uid INNER JOIN type ON article.tid=type.tid

返回查询结果如下:

aidtitleusernametypename
1文章1admin普通文章
2文章2admin精华文章
3文章3小明普通文章

MySQL LEFT JOIN 多表

使用 LEFT JOIN 三个表查询:

1 SELECT article.aid,article.title,user.username,type.typename FROM article LEFT JOIN user
2 ON article.uid=user.uid LEFT JOIN type ON article.tid=type.tid

返回查询结果如下:

aidtitleusernametypename
1文章1admin普通文章
2文章2admin精华文章
3文章3小明普通文章
4文章4NULL普通文章

MySQL RIGHT JOIN 多表

使用 RIGHT JOIN 三个表查询:

1 SELECT article.aid,article.title,user.username,type.typename FROM article RIGHT JOIN user
2 ON article.uid=user.uid RIGHT JOIN type ON article.tid=type.tid

返回查询结果如下:

aidtitleusernametypename
1文章1admin普通文章
2文章2admin精华文章
3文章3小明普通文章
NULLNULLNULL草稿

可见,在 RIGHT JOIN 右连接中,只是列出最后一个右连接表的所有数据。

说明

对于 MySQL 多表 JOIN,还可以 INNER、LEFT 和 RIGHT 混用,其返回结果与各关键字顺序有关,感兴趣可自行测试。

 

原文网址:http://blog.zhigui.org/2011/11/mysql-join/

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值