Mysql 多表連接查詢 inner join 和 outer join 的使用

來源:Mysql 多表連接查詢 inner join 和 outer join 的使用

JOIN的含義就如英文單詞“join”一樣渠缕,連接兩張表,大致分為內(nèi)連接舵匾,外連接,右連接谁不,左連接坐梯,自然連接。這里描述先甩出一張用爛了的圖刹帕,然后插入測(cè)試數(shù)據(jù)吵血。


首先先列舉本篇用到的分類(內(nèi)連接,外連接偷溺,交叉連接)和連接方法(如下):

A)內(nèi)連接:join蹋辅,inner join

B)外連接:left join,left outer join挫掏,right join侦另,right outer join,union

C)交叉連接:cross join

案例表:

t_users:

t_department:

第一種:內(nèi)連接 inner join

內(nèi)連接INNER JOIN是最常用的連接操作尉共。從數(shù)學(xué)的角度講就是求兩個(gè)表的交集褒傅,從笛卡爾積的角度講就是從笛卡爾積中挑出ON子句條件成立的記錄。

有INNER JOIN袄友,WHERE(等值連接)殿托,STRAIGHT_JOIN,JOIN(省略INNER)四種寫法。

selectd.id, d.department, t.namefrom t_users t

inner join t_department d on d.id = t.department_id

結(jié)果說明剧蚣;只去表A表和B表共同有的on 條件部分?jǐn)?shù)據(jù)支竹;

第二種:外連接 left join旋廷,left outer join ,right join唾戚, right outer join柳洋, union

1)左連接LEFT JOIN的含義就是求兩個(gè)表A表和B表的交集外加左表剩下的數(shù)據(jù)待诅。依舊從笛卡爾積的角度講叹坦,就是先從笛卡爾積中挑出ON子句條件成立的記錄,然后加上左表A表中剩余的記錄(見最后三條)卑雁。

where b.id is null



selectt.name, t.department_id, d.departmentfrom t_users tleftjoint_department dond.id=t.department_id


2)右連接 RIGHT JOIN

同理右連接RIGHT JOIN就是求兩個(gè)表A和B表的交集外加右表B剩下的數(shù)據(jù)募书。再次從笛卡爾積的角度描述,右連接就是從笛卡爾積中挑出ON子句條件成立的記錄测蹲,然后加上右表中剩余的記錄(見最后一條)


where a.id is null


selectt.id userid,t.name, t.department_id, d.departmentfrom t_users trightjoint_department dond.id=t.department_id

?3)外連接 FULL OUTER JOIN

外連接就是求兩個(gè)表A和B集合的并集莹捡。從笛卡爾積的角度講就是從笛卡爾積中挑出ON子句條件成立的記錄,然后加上左表中剩余的記錄扣甲,最后加上右表中剩余的記錄篮赢。另外MySQL不支持OUTER JOIN,但是我們可以對(duì)左連接和右連接的結(jié)果做?UNION?操作來實(shí)現(xiàn)琉挖。

情景一:A和B的并集


selectt.id userid,t.name, t.department_id, d.departmentfrom t_users tleftjoint_department dond.id= t.department_idUNIONselectt.id userid,t.name, t.department_id, d.departmentfrom t_users trightjoint_department dond.id=t.department_id

情景二:A和B中不滿足某個(gè)條件的記錄

如:即不在A表user里面启泣;也不在B表department里面的數(shù)據(jù);條件 is null

selectt.id userid,t.name, t.department_id, d.departmentfrom t_users tleftjoint_department dond.id= t.department_idwhered.idisnullUNIONselectt.id userid,t.name, t.department_id, d.departmentfrom t_users trightjoint_department dond.id= t.department_idwheret.department_idisnull

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末示辈,一起剝皮案震驚了整個(gè)濱河市寥茫,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌矾麻,老刑警劉巖纱耻,帶你破解...
    沈念sama閱讀 211,639評(píng)論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異险耀,居然都是意外死亡弄喘,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,277評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門甩牺,熙熙樓的掌柜王于貴愁眉苦臉地迎上來蘑志,“玉大人,你說我怎么就攤上這事柴灯÷袈” “怎么了?”我有些...
    開封第一講書人閱讀 157,221評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵赠群,是天一觀的道長(zhǎng)羊始。 經(jīng)常有香客問我,道長(zhǎng)查描,這世上最難降的妖魔是什么突委? 我笑而不...
    開封第一講書人閱讀 56,474評(píng)論 1 283
  • 正文 為了忘掉前任柏卤,我火速辦了婚禮,結(jié)果婚禮上匀油,老公的妹妹穿的比我還像新娘缘缚。我一直安慰自己,他們只是感情好敌蚜,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,570評(píng)論 6 386
  • 文/花漫 我一把揭開白布桥滨。 她就那樣靜靜地躺著,像睡著了一般弛车。 火紅的嫁衣襯著肌膚如雪齐媒。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,816評(píng)論 1 290
  • 那天纷跛,我揣著相機(jī)與錄音喻括,去河邊找鬼。 笑死贫奠,一個(gè)胖子當(dāng)著我的面吹牛唬血,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播唤崭,決...
    沈念sama閱讀 38,957評(píng)論 3 408
  • 文/蒼蘭香墨 我猛地睜開眼拷恨,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了浩姥?” 一聲冷哼從身側(cè)響起挑随,我...
    開封第一講書人閱讀 37,718評(píng)論 0 266
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎勒叠,沒想到半個(gè)月后兜挨,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,176評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡眯分,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,511評(píng)論 2 327
  • 正文 我和宋清朗相戀三年拌汇,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片弊决。...
    茶點(diǎn)故事閱讀 38,646評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡噪舀,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出飘诗,到底是詐尸還是另有隱情颜价,我是刑警寧澤炮叶,帶...
    沈念sama閱讀 34,322評(píng)論 4 330
  • 正文 年R本政府宣布,位于F島的核電站,受9級(jí)特大地震影響速侈,放射性物質(zhì)發(fā)生泄漏绍移。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,934評(píng)論 3 313
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望少欺。 院中可真熱鬧,春花似錦馋贤、人聲如沸赞别。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,755評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)仿滔。三九已至,卻和暖如春扰付,著一層夾襖步出監(jiān)牢的瞬間堤撵,已是汗流浹背仁讨。 一陣腳步聲響...
    開封第一講書人閱讀 31,987評(píng)論 1 266
  • 我被黑心中介騙來泰國(guó)打工羽莺, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人洞豁。 一個(gè)月前我還...
    沈念sama閱讀 46,358評(píng)論 2 360
  • 正文 我出身青樓盐固,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親丈挟。 傳聞我的和親對(duì)象是個(gè)殘疾皇子刁卜,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,514評(píng)論 2 348

推薦閱讀更多精彩內(nèi)容