一、多表連接類型
1. 笛卡爾積(交叉連接) 在MySQL中可以為CROSS JOIN或者省略CROSS即JOIN,或者使用',' 如:
由于其返回的結(jié)果為被連接的兩個數(shù)據(jù)表的乘積,因此當有WHERE, ON或USING條件的時候一般不建議使用,因為當數(shù)據(jù)表項目太多的時候,會非常慢。一般使用LEFT [OUTER] JOIN或者RIGHT [OUTER] JOIN
2. 內(nèi)連接INNER JOIN 在MySQL中把I
| SELECT * FROM table1 CROSS JOIN table2 SELECT * FROM table1 JOIN table2 SELECT * FROM table1,table2 |
NNER JOIN叫做等值連接,即需要指定等值連接條件在MySQL中CROSS和INNER JOIN被劃分在一起。 join_table: table_reference [INNER | CROSS] JOIN table_factor [join_condition]
3. MySQL中的外連接,分為左外連接和右連接,即除了返回符合連接條件的結(jié)果之外,還要返回左表(左連接)或者右表(右連接)中不符合連接條件的結(jié)果,相對應(yīng)的使用NULL對應(yīng)。
例子:
user表:
| id | name———1 | libk2 | zyfon3 | daodao |
user_action表:
| user_id | action—————1 | jump1 | kick1 | jump2 | run4 | swim |
sql:
| select id, name, action from user as u left join user_action a on u.id = a.user_id |
result:
| id | name | action——————————–1 | libk | jump ①1 | libk | kick ②1 | libk | jump ③2 | zyfon | run ④3 | daodao | null ⑤ |
分析:
注意到user_action中還有一個user_id=4, action=swim的紀錄,但是沒有在結(jié)果中出現(xiàn),
而user表中的id=3, name=daodao的用戶在user_action中沒有相應(yīng)的紀錄,但是卻出現(xiàn)在了結(jié)果集中
因為現(xiàn)在是left join,所有的工作以left為準.
結(jié)果1,2,3,4都是既在左表又在右表的紀錄,5是只在左表,不在右表的紀錄
工作原理:
從左表讀出一條,選出所有與on匹配的右表紀錄(n條)進行連接,形成n條紀錄(包括重復(fù)的行,如:結(jié)果1和結(jié)果3),如果右邊沒有與on條件匹配的表,那連接的字段都是null.然后繼續(xù)讀下一條。
引申:
我們可以用右表沒有on匹配則顯示null的規(guī)律, 來找出所有在左表,不在右表的紀錄, 注意用來判斷的那列必須聲明為not null的。
如:
sql:
| select id, name, action from user as u left join user_action a on u.id = a.user_id where a.user_id is NULL |
(注意:
1.列值為null應(yīng)該用is null 而不能用=NULL
2.這里a.user_id 列必須聲明為 NOT NULL 的.
)
上面sql的result:
新聞熱點
疑難解答
圖片精選