新聞中心
在《 MySQL交叉連接》一節(jié)中我們了解了 MySQL 的交叉連接,本節(jié)主要介紹多表查詢的另一種方式——內連接。

10年積累的成都網站設計、成都做網站經驗,可以快速應對客戶對網站的新想法和需求。提供各種問題對應的解決方案。讓選擇我們的客戶得到更好、更有力的網絡服務。我雖然不認識你,你也不認識我。但先做網站后付款的網站建設流程,更有張家界免費網站建設讓你可以放心的選擇與我們合作。
內連接(INNER JOIN)主要通過設置連接條件的方式,來移除查詢結果中某些數據行的交叉連接。簡單來說,就是利用條件表達式來消除交叉連接的某些數據行。
內連接使用
INNER JOIN 關鍵字連接兩張表,并使用 ON 子句來設置連接條件。
如果沒有連接條件,INNER JOIN 和 CROSS JOIN 在語法上是等同的,兩者可以互換。
內連接的語法格式如下:
SELECT <字段名> FROM <表1> INNER JOIN <表2> [ON子句]
語法說明如下。
- 字段名:需要查詢的字段名稱。
- <表1><表2>:需要內連接的表名。
- INNER JOIN :內連接中可以省略 INNER 關鍵字,只用關鍵字 JOIN。
- ON 子句:用來設置內連接的連接條件。
INNER JOIN 也可以使用 WHERE 子句指定連接條件,但是 INNER JOIN ... ON 語法是官方的標準寫法,而且 WHERE 子句在某些時候會影響查詢的性能。
多個表內連接時,在 FROM 后連續(xù)使用 INNER JOIN 或 JOIN 即可。
內連接可以查詢兩個或兩個以上的表。為了讓大家更好的理解,暫時只講解兩個表的連接查詢。
例 1
在 tb_students_info 表和 tb_course 表之間,使用內連接查詢學生姓名和相對應的課程名稱,SQL 語句和運行結果如下。
mysql> SELECT s.name,c.course_name FROM tb_students_info s INNER JOIN tb_course c
-> ON s.course_id = c.id;
+--------+-------------+
| name | course_name |
+--------+-------------+
| Dany | Java |
| Green | MySQL |
| Henry | Java |
| Jane | Python |
| Jim | MySQL |
| John | Go |
| Lily | Go |
| Susan | C++ |
| Thomas | C++ |
| Tom | C++ |
+--------+-------------+
10 rows in set (0.00 sec) 在這里的查詢語句中,兩個表之間的關系通過 INNER JOIN 指定,連接的條件使用 ON 子句給出。
注意:當對多個表進行查詢時,要在 SELECT 語句后面指定字段是來源于哪一張表。因此,在多表查詢時,SELECT 語句后面的寫法是表名.列名。另外,如果表名非常長的話,也可以給表設置別名,這樣就可以直接在 SELECT 語句后面寫上表的別名.列名。
新聞名稱:創(chuàng)新互聯數據庫教程:MySQLINNERJOIN:內連接
本文URL:http://m.5511xx.com/article/cccjcec.html


咨詢
建站咨詢
