MySQL的多表查詢(笛卡爾積原理) -1
阿新 • • 發佈:2022-02-15
- 先確定資料要用到哪些表。
- 將多個表先通過笛卡爾積變成一個表。
- 然後去除不符合邏輯的資料(根據兩個表的關係去掉)。
- 最後當做是一個虛擬表一樣來加上條件即可。
注意:列名最好使用表別名來區別。
笛卡爾積
Demo:
左,右連線,內,外連線
l內連線:
要點:返回的是所有匹配的記錄。
- 2.select * from a,b where a.x = b.x ////內連線
l外連線有左連線和右連線兩種。
要點:返回的是所有匹配的記錄 外加 每行主表外來鍵值為null的一條記錄。輔表所有列為null值。
- select * from a left join b on a.x=b.x order by a.x
- select * from a right join b on a.x=b.x order by a.x//右外連線或稱右連線
select子句順序
子句 |
說明 |
是否必須使用 |
select |
要返回的列或表示式 |
是 |
form |
從中檢索資料的表 |
僅在從表選擇資料時使用 |
where |
行級過濾 |
否 |
group by |
分組說明 |
僅在按組計算聚集時使用 |
having |
組級過濾 |
否 |
order by |
輸出排序順序 |
否 |
limit |
要檢索的行數 |
否 |