MySQL系列多表連接查詢92及99語法示例詳解教程
前面兩天帶著大家換了一個口味,帶著大家學習了pyecharts的原理和部分圖形制作。今天我們繼續(xù)回歸帶你學MySQL系列,帶著大家繼續(xù)學習MySQL數(shù)據(jù)庫。
多表查詢是數(shù)據(jù)分析師日常工作中一定會使用到的一個知識點,可見它的重要程度有多大。今天這個文章全面總結了MySQL多表查詢的幾種情況,你知道MySQL的92語法和99語法嗎?你知道等值連接和非等值連接嗎?不要覺得某些知識點用的少,就可以不知道,其實不然,至少別人寫出來后,你要知道是什么意思。
1.笛卡爾積現(xiàn)象

結果如下:

分析如下:
上述結果肯定是不對的,左表中每一個人都有4個男朋友,仔細觀察這4條記錄,正好是左表每一條記錄和右表一一匹配后的結果。
笛卡爾積現(xiàn)象產(chǎn)生的原因:兩張表沒有有效的連接條件。既然你沒有連接條件,本表中的第一行肯定是能和另外表中的所有行進行一一匹配,同理,本表中的第二行肯定是能和另外表中的所有行進行一一匹配,以此類推,本表中的最后一行m也可以和另外表中的所有行進行一一匹配。若另外一張表有n行,那么最后顯示的行數(shù),肯定就是m*n行了。
如果不想產(chǎn)生笛卡爾積現(xiàn)象,就需要添加有效的表連接條件。拿上述例子來說,左表boyfriend_id只有和右邊id相等時,才代表她們的男朋友。
添加表連接條件后:

可以看到,笛卡爾積最終產(chǎn)生的記錄數(shù)是兩張表中各自數(shù)據(jù)的乘積,當沒有使用連接查詢的時候,如果兩張表中數(shù)據(jù)特別大的時候,將會撐爆你的內(nèi)存,那是很可怕的,因此我們要學會使用連接查詢。
2.連接查詢知識點概括
1)什么是連接查詢?
在實際開發(fā)中,大多數(shù)的情況下都不是從單表中查詢數(shù)據(jù),一般都是多張表聯(lián)合查詢?nèi)〕鲎罱K的結果。也就是說:實際業(yè)務中也是一個業(yè)務由多個表構成,不同的信息存儲在不同的表中,如果我們想要獲取的信息來自多張表,此時你就需要使用連接查詢。
2)連接查詢的分類
① 按年代分類
MySQL中不支持全連接(full join),一般使用的是union關鍵字完成全連接的功能。MySQL中交叉連接是cross join,用的較少,我們也不用關心。
sq192標準:僅支持內(nèi)連接;sq199標準【推薦】:僅僅支持內(nèi)連接+外連接(僅支持左外和右外)+交叉連接; ② 按功能分類 內(nèi)連接:等值連接、非等值連接、自連接;外連接:左外連接、右外連接、全外連接(full join);
3.內(nèi)連接講解
原始數(shù)據(jù)如下:

1)等值連接:最大特點是,連接條件為等量關系。
習題:查詢員工名和對應的部門名;
sql92語法如下:(太老了,一般不用,看到了知道什么意思就行。)

sql99語法:(常用的)

2)sql92語法和sql99語法的區(qū)別。
-- sql92語法
select ename,dname
from emp,dept
where emp.deptno=dept.deptno;
-- sql99語法
select ename,dname
from emp (inner)join dept
on emp.deptno=dept.deptno;
-- sql92語法和sql99語法的區(qū)別
1)逗號(",")換成(inner)join;
2)where換成on;
注:inner可以省略,寫上inner可以增加代碼的可讀性。
--sql99語法的優(yōu)勢
表連接和后面的where條件篩選,分離開來。
對于sql92語法來說,表連接用的是where,where篩選用的也是where,混淆在一起不清不楚。
3)非等值連接:最大特點是,連接條件為非等量關系。

習題:找出每個員工的工資等級,要求顯示員工名、工資、工資等級。

4)自連接:最大特點是,一張表看作兩張表。
什么叫做一張表看作兩張表呢?也就是說,自連接是同一張表之間的連接,連接條件就是這張表中的不同字段。
人和機器的最大不同,就在于人有判斷能力,你知道區(qū)分使用一張表的不同字段,但是機器不知道,都是同一張表,字段名也都是相同的。那么,機器怎么才能區(qū)分哪個表是哪個表(對于同一張表來說)。
這就需要起別名了。對于同一張表來說,我給它取兩個名字,一個是A,一個是B,這樣機器就能很好的區(qū)分了。當取A表中的字段,就是"A.字段",取B表中的字段,就是"B.字段"。
習題:找出每個員工的上級領導,要求顯示員工名和對應的領導名。

4.外連接講解
原始數(shù)據(jù)如下:

1)什么是外連接,和內(nèi)連接有什么區(qū)別?
① 內(nèi)連接
假設A和B表進行連接,使用內(nèi)連接的話,凡是A表和B表能夠匹配上的記錄,就會查詢出來,這就是內(nèi)連接。AB兩張表沒有主副之分,兩張表是平等的。
② 外連接
假設A和B表進行連接,使用外連接的話,AB兩張表中有一張表是主表,一張表是副表,主要查詢主表中的數(shù)據(jù),捎帶著查詢副表。當副表中的數(shù)據(jù)沒有和主表中的數(shù)據(jù)匹配上,副表自動模擬出NULL與之匹配。
外連接最重要的特點是:主表的數(shù)據(jù),無條件的全部查詢出來。
2)外連接的分類
左連接有右連接的寫法,右連接也會有對應的左連接的寫法。因此,我們在學習MySQL的過程中,沒有必要既學習左連接又學習右連接。
左外連接(左連接):表示左邊的這張表是主表。右外連接(右連接):表示右邊的這張表是主表。 3)案例分析

習題:找出哪個部門沒有員工?

以上就是MySQL系列多表連接查詢92及99語法示例詳解教程的詳細內(nèi)容,更多關于MySQL查詢語法的資料請關注腳本之家其它相關文章!
相關文章
mysql中替代null的IFNULL()與COALESCE()函數(shù)詳解
這篇文章主要給大家介紹了關于mysql中替代null的IFNULL()與COALESCE()函數(shù)的相關資料,文中通過示例代碼介紹的非常詳細,對大家具有一定的參考學習價值,需要的朋友們下面來一起看看看吧。2017-06-06
MySQL連接拋出Authentication Failed錯誤的分析與解決思路
這篇文章主要給大家介紹了關于MySQL連接拋出Authentication Failed錯誤的分析與解決方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2018-10-10
MYSQL數(shù)據(jù)庫中的現(xiàn)有表增加新字段(列)
MYSQL 增加新字段的sql語句,需要的朋友可以參考下。2010-05-05

