亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

SQL語句匯總(終篇)—— 表聯(lián)接與聯(lián)接查詢

系統(tǒng) 2060 0

既然是最后一篇那就不能只列出些干枯的標(biāo)準(zhǔn)語句,更何況表聯(lián)接也是SQL中較難的部分,所以此次搭配題目來詳細(xì)闡述表聯(lián)接。

?

上一篇博文說到相關(guān)子查詢效率低下,那我們怎么能將不同表的信息一起查詢出來呢?這就需要用到表聯(lián)接。

和之前的UNION組合查詢不同,UNION是將不同的表組合起來,也就是縱向聯(lián)接,說白了就是豎著拼起來。

而表聯(lián)接是通過笛卡爾乘積將表進行橫向聯(lián)接,所謂的通過笛卡爾乘積簡單說就是兩表的行依次相聯(lián)再相加。要想更詳細(xì)的理解可以百度下,畢竟本文主要是匯總SQL語句。

現(xiàn)在有如下兩張表:

SQL語句匯總(終篇)—— 表聯(lián)接與聯(lián)接查詢

SQL語句匯總(終篇)—— 表聯(lián)接與聯(lián)接查詢

這是當(dāng)初老師布置的一份作業(yè),我偷個懶就不改數(shù)據(jù)了。不過把這些真神級人物的大名貼出來做“實驗”總覺得心里有很虛,更何況大部分都是IT業(yè)的。如有什么不敬我先道個歉,別跟我一般見識。

好了,扯遠(yuǎn)了。怎么聯(lián)接這兩張表呢?標(biāo)準(zhǔn)寫法:

      
        SELECT
      
      
        *
      
      
        FROM
      
       t_student 
      
        JOIN
      
       t_class 
    

結(jié)果這里只截一小部分圖,因為笛卡爾乘積后的行數(shù)等于兩張表的行數(shù)乘積,實在太多了。

SQL語句匯總(終篇)—— 表聯(lián)接與聯(lián)接查詢

這里就可以理解表聯(lián)接的原理了,依次相連再相加。當(dāng)然其中很多是無效行,為了去除無效的行我們就要用到外鍵來進行約束。學(xué)生表中的_fk與班級表中的_infor相關(guān)聯(lián):

      
        SELECT
      
      
        *
      
      
        FROM
      
       t_student s 
      
        JOIN
      
       t_class c 
      
        ON
      
       s._fk
      
        =
      
      c._infor; 
    

結(jié)果:

SQL語句匯總(終篇)—— 表聯(lián)接與聯(lián)接查詢

這里通過外鍵的匹配我們就得到了一張完美的聯(lián)接之后的表,它可以看做一張新表,想要任何數(shù)據(jù)均可以從此表中查詢,這就是表聯(lián)接的強大之處。

?

表聯(lián)接的分類:

內(nèi)聯(lián)接:

內(nèi)聯(lián)接是指兩個表中某一行相關(guān)的列值匹配時,這一行才會出現(xiàn)在表中。就像上例中s._fk與c._infor相同時才會出行該行,其他的行剔除。

語法為INNER JOIN 其中INNER可以省略。

內(nèi)聯(lián)接的簡寫:

      
        SELECT
      
      
        *
      
      
        FROM
      
       t_student s,t_class c 
      
        WHERE
      
       c._infor 
      
        =
      
       s._fk 
    

* 此寫法也是我們用的最多的。

?

外聯(lián)接:

分為左外聯(lián)接與右處聯(lián)接。

外聯(lián)接是指不管有沒有匹配,被定義了外聯(lián)接的表數(shù)據(jù)都要出現(xiàn)在結(jié)果中。比如左外聯(lián)接,那么在JOIN左邊的表就被定義為外聯(lián)接,那么此表中所有數(shù)據(jù)都會出現(xiàn)在查詢結(jié)果中。
注意班級表中的四班是沒有學(xué)生的,所以在內(nèi)聯(lián)接之后理所當(dāng)然的被剔除了。現(xiàn)在以外聯(lián)接做示例:
        
          SELECT
        
        
          *
        
        
          FROM
        
         t_student s 
        
          RIGHT
        
        
          JOIN
        
         t_class c 
        
          ON
        
         s._fk
        
          =
        
        c._infor; 
      

上面SQL中表t_class在寫在JOIN的右邊,所以我們用RIGHT JOIN來進行外聯(lián)接。

SQL語句匯總(終篇)—— 表聯(lián)接與聯(lián)接查詢

最下面多了一行四班的信息

例如我們想查出還沒有學(xué)生錄入的班級信息:

        
          SELECT
        
         c._id,c._cname,c._code 
        
          FROM
        
         t_student s 
        
          RIGHT
        
        
          JOIN
        
         t_class c 
        
          ON
        
         s._fk
        
          =
        
        c._infor 
        
          WHERE
        
         s._id 
        
          IS
        
        
          NULL
        
        ; 
      

這就是外聯(lián)接的用法,通常用在我們想要的數(shù)據(jù)匹配不上時。

?

自聯(lián)接:

自聯(lián)接屬于內(nèi)聯(lián)接或外聯(lián)接的一種特例,自聯(lián)接所聯(lián)接的表均是來自同一張,用法個人感覺還是比較巧妙的。

現(xiàn)有一表如下:

SQL語句匯總(終篇)—— 表聯(lián)接與聯(lián)接查詢

表中,6個人均屬于某公司的員工。區(qū)別是李四為張三和王五的領(lǐng)導(dǎo),張八為趙六和孫七的領(lǐng)導(dǎo)。 leader_id work_id 相關(guān)聯(lián)。

現(xiàn)在可以通過自聯(lián)接巧妙的將一張表分為員工部分和領(lǐng)導(dǎo)部分:

      
        SELECT
      
       w.work_name,l.work_name 領(lǐng)導(dǎo)姓名 
      
        FROM
      
       t_emp w,t_emp l 
      
        WHERE
      
       w.leader_id
      
        =
      
      l.work_id;
    

注意別名的用法

結(jié)果:

SQL語句匯總(終篇)—— 表聯(lián)接與聯(lián)接查詢

是不是有點方便?

?

知識點羅列到這里,做題時間到:

1.查詢鳳姐所在的班級

      
        SELECT
      
       _cname 
      
        FROM
      
       t_student s,t_class c 
      
        WHERE
      
       c._infor 
      
        =
      
       s._fk 
      
        AND
      
       s._name 
      
        =
      
      
        '
      
      
        鳳姐
      
      
        '
      
      ;
    

2.查詢同朱軍同班級的學(xué)生

      
        SELECT
      
       s._name 
      
        FROM
      
       t_student s 
      
        WHERE
      
       s._fk 
      
        =
      
      
         (

        
      
      
        SELECT
      
       cc._infor 
      
        FROM
      
       t_class cc,t_student ss 
      
        WHERE
      
       ss._fk 
      
        =
      
       cc._infor 
      
        AND
      
       ss._name 
      
        =
      
      
        '
      
      
        朱軍
      
      
        '
      
      
        

) 
      
      
        AND
      
       s._name 
      
        !=
      
      
        '
      
      
        朱軍
      
      
        '
      
      ;
    

本題中,括號內(nèi)為聯(lián)接后的表,其返回的是'朱軍'所在班級的_infor,然后主查詢在學(xué)生表中匹配與_infor相等的_fk的行,最后從匹配成功后的行中剔除'朱軍'自己。

3.查詢每個班級的人數(shù)

      
        SELECT
      
       d._cname,
      
        COUNT
      
      (_name) 
      
        FROM
      
       (
      
        SELECT
      
       ss.
      
        *
      
      ,cc._cname 
      
        FROM
      
       t_class cc 
      
        LEFT
      
      
        JOIN
      
       t_student ss 
      
        ON
      
       ss._fk 
      
        =
      
       cc._infor) d 
      
        GROUP
      
      
        BY
      
       d._cname;
    

本題中,括號內(nèi)為班級表外聯(lián)接后的表,并給該聯(lián)接后的表以別名d,按d的班級名稱d._cname分組后統(tǒng)計各班人數(shù)。這里之所以用外聯(lián)接還是因為四班沒有學(xué)生但依然要統(tǒng)計。

SQL語句匯總(終篇)—— 表聯(lián)接與聯(lián)接查詢

4.查詢班級人數(shù)最多的班級

      
        SELECT
      
       cc._cname,
      
        COUNT
      
      (_name) 
      
        FROM
      
       t_class cc,t_student ss 
      
        WHERE
      
       cc._infor 
      
        =
      
       ss._fk 
      
        GROUP
      
      
        BY
      
      
         cc._cname 
      
      
        HAVING
      
      
        COUNT
      
      (_name) 
      
        >=ALL
      
      
        (

    
      
      
        SELECT
      
      
        COUNT
      
      (_name) 
      
        FROM
      
       t_class c,t_student s 
      
        WHERE
      
       c._infor 
      
        =
      
       s._fk 
      
        GROUP
      
      
        BY
      
      
         c._cname

);
      
    

這個有點兇殘,用了兩次表聯(lián)接。括號內(nèi)返回的是每個班的人數(shù):

之后外部又使用了一次表聯(lián)接,將每個班的人數(shù)與括號內(nèi)的返回值逐一比較,得到最大值,然后找到最大值所在的班級。這里就體現(xiàn)了對SQL執(zhí)行順序的理解有多重要了,聯(lián)接、分組、過濾等等的先后順序。

結(jié)果:

5.查詢每個班中年齡最低的人

      
        SELECT
      
       cc._cname,ss._name,ss._age 
      
        FROM
      
       t_student ss,t_class cc 
      
        WHERE
      
       ss._fk 
      
        =
      
       cc._infor 
      
        AND
      
       ss._age 
      
        <=ALL
      
      
        (

    
      
      
        SELECT
      
      
        MIN
      
      (s._age) 
      
        FROM
      
       t_student s 
      
        WHERE
      
       ss._fk 
      
        =
      
      
         s._fk

);
      
    

本題中,括號內(nèi)部返回一個學(xué)生表中的最小年齡,外部進行表聯(lián)接后將年齡列對返回值進行比較,若小于等于返回的最小值那其本身也為最小值。

如果括號內(nèi)部不加判斷條件WHERE ss._fk = s._fk,則最后只會查詢出一條年齡最小的數(shù)據(jù),而并沒有按我們想要的查詢出每個班的最小值。

如:

有人會問了既然按班分,用分組不就好了?但要注意的是最小年齡的人不只一個,而分組后每一個班只會顯示一個人。所以這里用了關(guān)聯(lián)條件WHERE ss._fk = s._fk來讓內(nèi)外表關(guān)聯(lián),從而統(tǒng)計出所有我們想要的值。

結(jié)果:

SQL語句匯總(終篇)—— 表聯(lián)接與聯(lián)接查詢

?

這里終于把這個小系列寫完了,非常非常感謝各位的支持,接下來打算分享一些有趣實用的東西,希望大家繼續(xù)支持,謝謝!

SQL語句匯總(終篇)—— 表聯(lián)接與聯(lián)接查詢


更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯(lián)系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發(fā)表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 久久免费视频8 | 午夜视频在线观看网站 | 九九国产在线 | 久久这里 | 在线观看 日韩 | 亚洲欧美另类精品久久久 | 亚洲有色| 国内精品久久久久尤物 | 亚洲欧美v视色一区二区 | a大片久久爱一级 | 久久九九爱 | 理论片 我不卡影院 | 国产精品毛片久久久久久久 | 国产精品伦理久久久久 | 97视频在线观看免费视频 | 毛片毛片毛片毛片毛片毛片毛片 | 亚洲精品中文字幕乱码三区一二 | 日本αv| 在线成人爽a毛片免费软件 在线成人天天鲁夜啪视频 在线成人亚洲 | 国产精品怡红院永久免费 | 亚洲最大视频网 | 国产精品久久久久aaaa | 天天射天 | 欧美乱大交xxxxxbbb | 色婷婷99综合久久久精品 | 国产色视频一区二区三区 | 999精品视频在线 | 精品久久久日韩精品成人 | 国产日韩欧美精品在线 | 国产手机在线国内精品 | 天堂精品在线 | 97超视频在线观看 | 美女视频免费在线观看 | 国产高清在线精品一区二区 | 久久乐国产综合亚洲精品 | 波霸欧美性猛交xxxxxx | 中文字幕不卡 | 精品老司机在线观看视频 | 成人免费视频网 | 国产手机在线精品 | 国产综合精品一区二区 |