MySQL高級查詢示例詳細介紹
目錄
- 1.左關聯
- 2.右關聯
- 3.子查詢
- 4.聯合查詢
- 5.分組查詢
1.左關聯
MySQL中的左關聯(Left Join)是一種基于共同列的連接操作,
它將左側表中的所有行與右側表中匹配的行結合在一起,
如果右側表中沒有匹配的行,則結果集中右側表中的所有列將顯示為NULL。
左側表是指在關鍵字LEFT JOIN中出現在關鍵字左側的表。
下面是一個使用MySQL的LEFT JOIN進行連接操作的簡單示例:
假設我們有兩個表,一個是學校表(school),包含學校的ID和名稱:
另一個是年級表(grade),包含年級的ID、學校ID和年級名稱:
編程目標:我們可以使用以下代碼來獲取所有學校及其年級信息:
SELECT school.school_name as "學校名稱", grade.grade_name as "年級名稱"FROM school LEFT JOIN grade ON school.id = grade.school_id;
運行結果:
這將返回一個結果集,其中包含所有學校及其年級信息,
如果學校沒有年級,則年級名稱將顯示為NULL。
左關聯操作確保我們可以獲取所有學校的信息,即使它們沒有年級數據。
2.右關聯
MySQL中的右關聯(Right Join)是一種基于共同列的連接操作,
它將右側表中的所有行與左側表中匹配的行結合在一起,
如果左側表中沒有匹配的行,則結果集中左側表中的所有列將顯示為NULL。
右側表是指在關鍵字RIGHT JOIN中出現在關鍵字右側的表。
右關聯與左關聯的區別在于哪個表是主表和次要表,
即右關聯的主表是右側表,次要表是左側表,
而左關聯的主表是左側表,次要表是右側表。
假設有兩個表,一個是學校表(school),包含學校的ID和名稱,
另一個是年級表(grade),包含年級的ID、學校ID和年級名稱。
編程目標:我們可以使用以下代碼來獲取所有學校及其年級信息:
select school.school_name as "學校名稱", grade.grade_name as "年級名稱"from school right join gradeon school.id = grade.school_id;
運行結果:
這將返回一個結果集,其中包含所有年級及其所屬學校信息,
如果年級沒有對應的學校信息,則學校名稱將顯示為NULL。
右關聯操作確保我們可以獲取所有年級的信息,即使它們沒有對應的學校數據。
注意:右關聯和左關聯的區別在于哪個表是主表和次要表,即
右關聯的主表是年級表,次要表是學校表,
而左關聯的主表是學校表,次要表是年級表。
3.子查詢
MySQL中的子查詢(Subquery)是一種在SELECT語句中使用的嵌套查詢,用于從另一個查詢的結果集中檢索數據。子查詢可以用作WHERE或HAVING語句中的條件,或者用作SELECT語句中的列。子查詢可以返回單個值、一列值或一組行。
現在,我們假設有兩個表,
一個是學校表(school),包含學校的ID和名稱,
另一個是年級表(grade),包含年級的ID、學校ID和年級名稱。
編程目標:以下是一個使用子查詢的示例,用于檢索包含特定年級名稱的學校列表:
SELECT school_nameFROM schoolWHERE id IN ( SELECT school_id FROM grade WHERE grade_name = "三年級");
運行結果:
這將返回一個結果集,其中包含所有包含名為"三年級"的年級的學校的名稱。
子查詢用于獲取包含特定年級的學校ID,
主查詢用于從學校表中檢索對應的學校名稱。
另一個示例是使用子查詢和聚合函數檢索每個學校的年級數。
例如,以下查詢使用子查詢和COUNT函數從"年級表"中獲取每個學校的年級數,
并將其與"學校表"中的學校名稱一起返回:
SELECT school.school_name, (SELECT COUNT(*) FROM grade WHERE grade.school_id = school.school_id) as grade_countFROM school;
運行結果:
這將返回一個結果集,
其中包含每個學校的名稱和年級數。
子查詢在內部查詢中使用COUNT函數從年級表中檢索與學校ID匹配的行數。
主查詢用于從學校表中檢索學校名稱,并將子查詢返回的年級數作為附加列一起返回。
4.聯合查詢
MySQL中的聯合查詢(UNION)用于將多個SELECT語句的結果組合成一個結果集。
每個SELECT語句必須具有相同的列數和相似的數據類型,
而聯合查詢將自動對結果進行排序和去重。
可以使用UNION ALL來保留重復的行。
假設有兩個表,一個是學校表(school),包含學校的ID和名稱,
另一個是年級表(grade),包含年級的ID、學校ID和年級名稱。
以下是一個使用UNION查詢的示例,用于檢索所有學校的名稱和所有年級的名稱,這些學校和年級存儲在不同的表中:
SELECT school_name FROM schoolUNIONSELECT grade_name FROM grade;
運行結果:
這將返回一個結果集,其中包含所有學校的名稱和所有年級的名稱。UNION操作將自動對結果集進行去重,并按名稱排序。
如果要將學校和年級的名稱分開,可以使用別名將兩個SELECT語句的結果列重命名:
SELECT school_name, NULL AS grade_name FROM schoolUNIONSELECT NULL AS school_name, grade_name FROM grade;
運行結果:
這將返回一個結果集,其中包含學校名稱和年級名稱的兩個列。
注意,由于兩個表中的名稱列位于不同的位置,因此必須使用NULL作為占位符,以確保SELECT語句中的列數相同。
5.分組查詢
MySQL中的分組查詢(GROUP BY)用于將查詢結果按照一個或多個列進行分組,并對每個分組應用聚合函數。GROUP BY子句必須跟在SELECT語句之后,并指定要分組的列名稱。
假設有兩個表,一個是學校表(school),包含學校的ID和名稱,
另一個是年級表(grade),包含年級的ID、學校ID和年級名稱。
以下是一個使用分組查詢的示例,用于檢索每個學校的年級數:
SELECT school_name, COUNT(g.id) AS grade_countFROMschool s LEFT JOIN grade g ON s.id = g.school_idGROUP BY s.id;
運行結果:
這將返回一個結果集,其中包含每個學校的名稱和年級數。
在這個查詢中,使用LEFT JOIN將兩個表連接起來,并使用GROUP BY子句按學校ID分組。
注意,在GROUP BY子句中使用了學校表的ID列,而不是名稱列。
使用COUNT函數計算每個學校的年級數。
到此這篇關于MySQL高級查詢示例詳細介紹的文章就介紹到這了,更多相關MySQL高級查詢內容請搜索以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持!
