mysql多表查詢

表與表的關(guān)系

表與表的關(guān)系有三種:一對一翔烁,一對多(多對一)缓窜,多對多腐魂。在確定表與表的關(guān)系的時(shí)候需要確定主表和從表翩腐,依賴性更強(qiáng)的是從表,必須存在的是主表蓝谨,這樣就可以知道外鍵該設(shè)置在那個(gè)表中了灌具。


一對多:一個(gè)部門可以有多個(gè)員工,一個(gè)員工只能屬于一個(gè)部門譬巫; 一個(gè)客戶對應(yīng)多個(gè)聯(lián)系人咖楣,一個(gè)聯(lián)系人只能屬于某一個(gè)客戶。


一對多建表原則:在多的一方創(chuàng)建外鍵對應(yīng)一的一方的主鍵芦昔。


多對多:一個(gè)學(xué)生可以選擇多門課程诱贿,一門課程可以被多個(gè)學(xué)生選擇;一個(gè)訂單可以包含多個(gè)商品咕缎,一個(gè)商品可以在多個(gè)訂單中珠十;一個(gè)用戶可以選擇多個(gè)角色,一個(gè)角色可以被多個(gè)用戶選擇凭豪。


多對多建表原則:創(chuàng)建中間表焙蹭,中間表中至少有兩個(gè)字段分別作為外鍵指向多對多雙方的主鍵。(主鍵對應(yīng))


一對一:一般都建一張表墅诡。


一對一建表原則:唯一外鍵對應(yīng)/主鍵對應(yīng)壳嚎。(不常用桐智,且可合并)

一對一


?? 一對一是將數(shù)據(jù)表“垂直切分”,其實(shí)是不常見烟馅,或不常用的说庭。也就是 A 表的一條記錄對應(yīng) B 表的一條記錄,為什么要這樣的設(shè)計(jì)呢郑趁,不是增加了程度的復(fù)雜性嗎刊驴,然而并不一定,舉例說明:



1)? 一個(gè)系統(tǒng)必然有 Employee(員工表)(包含字段:EmployeeId寡润、姓名捆憎、性別、年齡梭纹、電話躲惰、地址等),每個(gè)員工都為一個(gè)用戶变抽,所以還有張 User 表(包含字段:UserId(關(guān)聯(lián) EmployeeId)础拨、用戶名、密碼绍载、角色等)诡宗,這樣你會發(fā)現(xiàn),整合為一張表是否不太妥當(dāng)击儡?因?yàn)樗郑琔ser 的記錄只會在登錄時(shí)用到,感覺有點(diǎn)違背三大范式中的“確保每列都和主鍵列直接關(guān)聯(lián)阳谍,而不是間接關(guān)聯(lián)”蛀柴。



2)? 還有種情況,這就要根據(jù)具體的業(yè)務(wù)來決定了边坤。如果名扛,當(dāng)一張表的字段過于太多谅年,而很多字段可能只有在某些情況下茧痒,才會使用到,這時(shí)也可以考慮使用一對一設(shè)計(jì)融蹂。



?? 優(yōu)點(diǎn)


1.? 便于管理旺订、可提高一定的查詢速度


2.? 減輕 CPU 的 IO 讀寫,提高存取效率超燃。


3.? 符合數(shù)據(jù)庫設(shè)計(jì)的三大范式区拳。


4.? 符合關(guān)系性數(shù)據(jù)庫的特性。



?? 缺點(diǎn)


1.? 增加一定的復(fù)雜程度意乓,程序中的讀寫難度加大樱调。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子笆凌,更是在濱河造成了極大的恐慌圣猎,老刑警劉巖,帶你破解...
    沈念sama閱讀 219,427評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件乞而,死亡現(xiàn)場離奇詭異送悔,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)爪模,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,551評論 3 395
  • 文/潘曉璐 我一進(jìn)店門欠啤,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人屋灌,你說我怎么就攤上這事洁段。” “怎么了共郭?”我有些...
    開封第一講書人閱讀 165,747評論 0 356
  • 文/不壞的土叔 我叫張陵眉撵,是天一觀的道長。 經(jīng)常有香客問我落塑,道長纽疟,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,939評論 1 295
  • 正文 為了忘掉前任憾赁,我火速辦了婚禮污朽,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘龙考。我一直安慰自己蟆肆,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,955評論 6 392
  • 文/花漫 我一把揭開白布晦款。 她就那樣靜靜地躺著炎功,像睡著了一般。 火紅的嫁衣襯著肌膚如雪缓溅。 梳的紋絲不亂的頭發(fā)上蛇损,一...
    開封第一講書人閱讀 51,737評論 1 305
  • 那天,我揣著相機(jī)與錄音坛怪,去河邊找鬼淤齐。 笑死,一個(gè)胖子當(dāng)著我的面吹牛袜匿,可吹牛的內(nèi)容都是我干的更啄。 我是一名探鬼主播,決...
    沈念sama閱讀 40,448評論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼居灯,長吁一口氣:“原來是場噩夢啊……” “哼祭务!你這毒婦竟也來了内狗?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,352評論 0 276
  • 序言:老撾萬榮一對情侶失蹤义锥,失蹤者是張志新(化名)和其女友劉穎其屏,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體缨该,經(jīng)...
    沈念sama閱讀 45,834評論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡偎行,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,992評論 3 338
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了贰拿。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片蛤袒。...
    茶點(diǎn)故事閱讀 40,133評論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖膨更,靈堂內(nèi)的尸體忽然破棺而出妙真,到底是詐尸還是另有隱情,我是刑警寧澤荚守,帶...
    沈念sama閱讀 35,815評論 5 346
  • 正文 年R本政府宣布珍德,位于F島的核電站,受9級特大地震影響矗漾,放射性物質(zhì)發(fā)生泄漏锈候。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,477評論 3 331
  • 文/蒙蒙 一敞贡、第九天 我趴在偏房一處隱蔽的房頂上張望泵琳。 院中可真熱鬧,春花似錦誊役、人聲如沸获列。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,022評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽击孩。三九已至,卻和暖如春鹏漆,著一層夾襖步出監(jiān)牢的瞬間巩梢,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,147評論 1 272
  • 我被黑心中介騙來泰國打工甫男, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留且改,地道東北人验烧。 一個(gè)月前我還...
    沈念sama閱讀 48,398評論 3 373
  • 正文 我出身青樓板驳,卻偏偏與公主長得像,于是被迫代替她去往敵國和親碍拆。 傳聞我的和親對象是個(gè)殘疾皇子若治,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,077評論 2 355

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

  • 一慨蓝、表的關(guān)系分析: 用戶和訂單:一個(gè)用戶可以有多個(gè)訂單,但每個(gè)訂單只能屬于一個(gè)用戶端幼,所以是一對多的關(guān)系礼烈。商品和分類...
    zengsiyong閱讀 7,255評論 0 10
  • 一、多表 1婆跑、表與表之間的關(guān)系與實(shí)現(xiàn) 1.1此熬、一對一 實(shí)現(xiàn):在任何一方添加外鍵指向另一方法的主鍵 1.2、一對多 ...
    一花一世界yu閱讀 204評論 0 1
  • 多表查詢 1. 表與表之間的關(guān)系 <1> 一對一 用戶表和身份信息表滑进,用戶表是主表 男人表犀忱、女人表 create...
    若塵___閱讀 272評論 0 1
  • 首先我們來了解一下表與表之間的關(guān)系:一對一、一對多扶关、多對多阴汇。這里我們把多表查詢分為四個(gè)學(xué)習(xí)模塊:連接查詢、合并結(jié)果...
    lily_5945閱讀 254評論 0 1
  • /*-- 創(chuàng)建部門表create table tb_dept(id int primary key auto_in...
    小灰灰愛學(xué)習(xí)閱讀 791評論 0 0