MySQL內連接(INNER JOIN)是一種常用的關聯查詢方式,通常用于多個表之間的數據查詢和篩選。在一對多關系場景中,INNER JOIN可以幫助我們從左表中查找到右表符合條件的數據,并將它們連接在一起返回。
例如,我們有兩個表,一個是“學生表”(students),另一個是“成績表”(scores)。
CREATE TABLE students ( id INT PRIMARY KEY, name VARCHAR(30), age INT ); CREATE TABLE scores ( id INT PRIMARY KEY, student_id INT, course VARCHAR(30), score INT ); INSERT INTO students VALUES (1, '張三', 18); INSERT INTO students VALUES (2, '李四', 19); INSERT INTO students VALUES (3, '王五', 20); INSERT INTO scores VALUES (1, 1, '數學', 90); INSERT INTO scores VALUES (2, 1, '語文', 95); INSERT INTO scores VALUES (3, 2, '數學', 85); INSERT INTO scores VALUES (4, 2, '語文', 93); INSERT INTO scores VALUES (5, 3, '數學', 88);
我們要查詢每個學生的姓名和平均分數,這時就需要使用INNER JOIN:
SELECT students.name, AVG(scores.score) AS avg_score FROM students INNER JOIN scores ON students.id = scores.student_id GROUP BY students.id
INNER JOIN語句將左表(students)和右表(scores)連接起來,連接條件是“students.id = scores.student_id”。查詢結果會返回每個學生的姓名和平均分數。
當一個學生在成績表中有多條記錄時,INNER JOIN會將這些記錄組合到一起計算平均分數,這就是一對多的情況。
使用INNER JOIN時需要注意的是,連接條件必須是精確匹配,否則會返回錯誤的結果。如果連接條件不精確,可以考慮使用其他類型的連接查詢。