在 MySQL 中,兩張表的關(guān)聯(lián)是通過一個(gè)或多個(gè)共同字段進(jìn)行的。這些共同字段將數(shù)據(jù)在兩張表之間進(jìn)行匹配,使我們可以從兩張表中查詢相關(guān)聯(lián)的數(shù)據(jù)。
下面是兩張表如何進(jìn)行關(guān)聯(lián)的示例:
CREATE TABLE table1 (
id INT UNSIGNED NOT NULL PRIMARY KEY,
name CHAR(30) NOT NULL,
address VARCHAR(50) NOT NULL
);
CREATE TABLE table2 (
id INT UNSIGNED NOT NULL PRIMARY KEY,
table1_id INT UNSIGNED NOT NULL,
phone CHAR(12) NOT NULL,
FOREIGN KEY (table1_id) REFERENCES table1(id)
);
在這個(gè)示例中,我們有兩張表:table1 和 table2。在 table1 中,我們有一個(gè)主鍵列 id,另外還有兩列 name 和 address。在 table2 中,我們同樣有一個(gè)主鍵列 id,還有一個(gè)外鍵列 table1_id 和一列 phone。
為了進(jìn)行表關(guān)聯(lián),我們需要在兩張表中有相同的列。在這個(gè)示例中,我們可以使用 table1 的 id 和 table2 的 table1_id 進(jìn)行關(guān)聯(lián)。我們可以使用下面的 SQL 語句來執(zhí)行這個(gè)關(guān)聯(lián)操作:
SELECT table1.name, table1.address, table2.phone
FROM table1
INNER JOIN table2
ON table1.id = table2.table1_id;
上面的 SQL 語句使用 INNER JOIN 關(guān)鍵字將兩張表進(jìn)行關(guān)聯(lián)。在 ON 子句中,我們指定了用于關(guān)聯(lián)兩張表的列:table1.id 和 table2.table1_id。這意味著只有在 table1.id 等于 table2.table1_id 時(shí),兩張表中的數(shù)據(jù)才會(huì)被匹配。
上面就是 MySQL 中兩張表關(guān)聯(lián)的基本知識(shí)。通過使用 INNER JOIN,我們可以很容易地從多張表中獲取我們所需的數(shù)據(jù)。