MySQL使用連接實現多表檢索
阿新 • • 發佈:2018-06-21
不同 查詢 結果 null 定義 連接 產生 SQ 建議
1.內連接:
INNER JOIN ,CRROSS JOIN,JOIN在MySQL中是等價的連接,會產生笛卡爾積。
連接運算符","(逗號)與之類似,但逗號運算符的優先級與其他連接類型的有所不同。有時,在其他連接類型的都正常的情況下,它會導致語法錯誤,因此建議盡量避免使用逗號運算符
其他語法格式:使用ON子句代替WHERE子句。如:SELECT t1.*,t.* FROM t1 INNER JOIN t2 ON t1.i1 = t2.i2
使用USING()子句。它在概念上類似於ON子句,但要求被連接的列必須同名。如以下的查詢語句可以將mytbl1.b連接到mytbl2.b
SELECT mytbl1.*,mytbl2.* FORM mytbl1 INNER JOIN mytbl2 USING (b);
2.左外連接和右外連接
左外連接是使用LEFT JOIN,右外連接使用RIGHT JOIN
LEFT JOIN 的工作方式是:先指定用於對兩個表裏的行進行匹配的列;接著,當左表的某行右表的某行相匹配時,兩行的內容會被選取為一個輸出行;當左表的某行在右表裏無匹配時,
它仍然會被選取為一個輸出行,只是與它連接的是右表的一個假行,其中的每一列都包含NULL。
在使用時需要註意這樣一個問題,即只有將右表裏的列全部定義為not null的結果集裏的行才沒有什麽問題。例如,右表裏包含值為NULL的列,那麽就無法將這些null值與標識未匹配行的那些null值區別開來。
MySQL使用連接實現多表檢索