天天看點

MySQL JOIN 多表連接配接

ySQL JOIN 多表連接配接

除了常用的兩個表連接配接之外,SQL(MySQL) JOIN 文法還支援多表連接配接。多表連接配接基本文法如下:

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

JOIN 多表連接配接實作了從多個表中擷取相關資料,下面是三個原始資料表:

article 文章表:

aid title content uid tid
1 文章1 文章1正文内容... 1 1
2 文章2 文章2正文内容... 1 2
3 文章3 文章3正文内容... 2 1
5 文章5 文章5正文内容... 4 1

user 使用者表:

uid username email
1 admin [email protected]
2 小明 [email protected]
3 Jack [email protected]

type 文章類型表:

tid typename
1 普通文章
2 精華文章
3 草稿

MySQL INNER JOIN 多表

我們使用 INNER JOIN 列出三個表中都具有關聯關系的資料:

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

傳回查詢結果如下:

aid title username typename
1 文章1 admin 普通文章
2 文章2 admin 精華文章
3 文章3 小明 普通文章

MySQL LEFT JOIN 多表

使用 LEFT JOIN 三個表查詢:

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

傳回查詢結果如下:

aid title username typename
1 文章1 admin 普通文章
2 文章2 admin 精華文章
3 文章3 小明 普通文章
4 文章4 NULL 普通文章

MySQL RIGHT JOIN 多表

使用 RIGHT JOIN 三個表查詢:

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

傳回查詢結果如下:

aid title username typename
1 文章1 admin 普通文章
2 文章2 admin 精華文章
3 文章3 小明 普通文章
NULL NULL NULL 草稿

可見,在 RIGHT JOIN 右連接配接中,隻是列出最後一個右連接配接表的所有資料。

出自:http://www.5idev.com/p-php_mysql_join_multi_table.shtml