【MySQL筆記】4 子查詢與創(chuàng)建聯(lián)結(jié)

MySQL筆記基于教材缰盏,筆記中用到的數(shù)據(jù)庫可以點擊該鏈接下載

子查詢 Subquery

  • 在多張表間查詢相關(guān)的信息時,可以將SELECT語句嵌套起來用口猜;
  • 子查詢經(jīng)常與WHERE子句里的IN一起使用济炎;
  • 列必須匹配:在WHERE子句中使用子查詢,應保證SELECT語句和WHERE語句有相同數(shù)目的列冻辩。通常WHERE使用單個列拆祈,而SELECT也返回單個列倘感。
查詢購買了產(chǎn)品號(prod_id)為TNT2的產(chǎn)品的顧客信息

SELECT cust_name, cust_contact
FROM customers
WHERE cust_id IN (SELECT cust_id
                  FROM orders
                  WHERE order_num IN (SELECT order_num
                                      FROM orderitems
                                      WHERE prod_id = 'TNT2'));

也可以將子查詢用在計算字段里,則每一行都會執(zhí)行一次子查詢

查詢每個客戶的訂單數(shù)

SELECT cust_name, cust_state, 
       (SELECT COUNT(*)
        FROM orders
        WHERE orders.cust_id = customers.cust_id) AS orders
FROM customers
ORDER BY cust_name;

聯(lián)結(jié) Join

Terminology

  • 外鍵 (foreign key):外鍵為某個表中一列淤年,它包含另外一個表的主鍵值蜡豹,定義了兩個表之間的關(guān)系。
  • 可伸縮性 (scale):能夠適應不斷增加的工作量而不失效弄诲。設計良好的數(shù)據(jù)庫或應用程序稱之為可伸縮型好 (scale well)娇唯。
  • 關(guān)系數(shù)據(jù)庫將相關(guān)的數(shù)據(jù)分多個表存儲,用各表的主鍵聯(lián)系塔插。這樣的數(shù)據(jù)庫維護方便,處理靈活伶授。因此關(guān)系數(shù)據(jù)庫的可伸縮性要遠優(yōu)于非關(guān)系數(shù)據(jù)庫流纹。

Application

在MySQL中可以通過WHERE子句聯(lián)結(jié)兩個或更多表。在FROM子句中給出要聯(lián)結(jié)的所有表漱凝,在WHERE子句中建立聯(lián)結(jié)的關(guān)系。

查找所有供應商生產(chǎn)的所有產(chǎn)品

SELECT vend_name, prod_name, prod_price #列vend_name來自vendors, 后兩列來自products
FROM vendors, products #聯(lián)結(jié)了表vendors和表products
WHERE vendors.vend_id = products.vend_id #關(guān)系是兩個表中行的vend_id相同
ORDER BY vend_name, prod_name;

上述聯(lián)結(jié)由特定列的相等關(guān)系來聯(lián)結(jié)行。這種聯(lián)結(jié)被稱為"等值聯(lián)結(jié)" (equijoin)扣典。它基于兩個表之間的相等測試慎玖。這種聯(lián)結(jié)也稱為"內(nèi)部聯(lián)結(jié)"。

實際上趁怔,這種聯(lián)結(jié)有專門的語法薪前。

SELECT vend_name, prod_name, prod_price
FROM vendors INNER JOIN products #在FROM子句中用INNER JOIN指明聯(lián)結(jié)類型
ON vendors.vend_id = products.vend_id #在下一行用ON建立聯(lián)結(jié)

也可以多個表聯(lián)結(jié)关斜。只要把關(guān)系在WHERE子句中寫清楚就可以。


MySQL系列筆記


最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市丁稀,隨后出現(xiàn)的幾起案子枷踏,更是在濱河造成了極大的恐慌,老刑警劉巖枯跑,帶你破解...
    沈念sama閱讀 216,402評論 6 499
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件矗积,死亡現(xiàn)場離奇詭異,居然都是意外死亡辜腺,警方通過查閱死者的電腦和手機乍恐,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,377評論 3 392
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來百匆,“玉大人呜投,你說我怎么就攤上這事÷丶觯” “怎么了?”我有些...
    開封第一講書人閱讀 162,483評論 0 353
  • 文/不壞的土叔 我叫張陵啥寇,是天一觀的道長。 經(jīng)常有香客問我衰絮,道長磷醋,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,165評論 1 292
  • 正文 為了忘掉前任镊掖,我火速辦了婚禮褂痰,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘缩歪。我一直安慰自己,他們只是感情好主籍,可當我...
    茶點故事閱讀 67,176評論 6 388
  • 文/花漫 我一把揭開白布逛球。 她就那樣靜靜地躺著,像睡著了一般幸海。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上物独,一...
    開封第一講書人閱讀 51,146評論 1 297
  • 那天氯葬,我揣著相機與錄音,去河邊找鬼官研。 笑死闯睹,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的瞻坝。 我是一名探鬼主播,決...
    沈念sama閱讀 40,032評論 3 417
  • 文/蒼蘭香墨 我猛地睜開眼衙荐,長吁一口氣:“原來是場噩夢啊……” “哼浮创!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起溜族,我...
    開封第一講書人閱讀 38,896評論 0 274
  • 序言:老撾萬榮一對情侶失蹤垦沉,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后厕倍,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,311評論 1 310
  • 正文 獨居荒郊野嶺守林人離奇死亡况既,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,536評論 2 332
  • 正文 我和宋清朗相戀三年棒仍,在試婚紗的時候發(fā)現(xiàn)自己被綠了臭胜。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,696評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡榜配,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出蛋褥,到底是詐尸還是另有隱情睛驳,我是刑警寧澤,帶...
    沈念sama閱讀 35,413評論 5 343
  • 正文 年R本政府宣布淫茵,位于F島的核電站蹬跃,受9級特大地震影響匙瘪,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,008評論 3 325
  • 文/蒙蒙 一丹喻、第九天 我趴在偏房一處隱蔽的房頂上張望薄货。 院中可真熱鬧,春花似錦碍论、人聲如沸谅猾。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,659評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽税娜。三九已至,卻和暖如春藏研,著一層夾襖步出監(jiān)牢的瞬間敬矩,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,815評論 1 269
  • 我被黑心中介騙來泰國打工遥倦, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留谤绳,地道東北人。 一個月前我還...
    沈念sama閱讀 47,698評論 2 368
  • 正文 我出身青樓缩筛,卻偏偏與公主長得像,于是被迫代替她去往敵國和親堡称。 傳聞我的和親對象是個殘疾皇子瞎抛,可洞房花燭夜當晚...
    茶點故事閱讀 44,592評論 2 353