MySql多表鏈接查詢詳細教程
1.什么是連接查詢:
在實際開發(fā)中大部分都不是從一張表中查詢數(shù)據(jù),一般都是多張表聯(lián)合查詢?nèi)〉媒Y(jié)果。
實際開發(fā)中,一般一個業(yè)務(wù)對應(yīng)多張表。比如:學(xué)生和班級,起碼兩張。(因為一張表可能會出現(xiàn)冗余的情況,即數(shù)據(jù)大量重復(fù)?。?/p>
2. 連接查詢的分類:
1)根據(jù)出現(xiàn)年代來劃分,包括:
sql92(一些老的DBA還在使用的語法,已經(jīng)被淘汰)
sql99(比較新的語法)
2)根據(jù)表的連接方式劃分,包括:
內(nèi)連接: 等值連接
? 非等值連接
? 自鏈接
外連接: 左外連接(左連接)
? 右外連接(右連接)
*全連接(很少用,了解)
3.笛卡爾積現(xiàn)象:
在表的連接查詢方面的一種現(xiàn)象:當(dāng)兩張表進行查詢的的時候,沒有任何條件限制,最終的查詢結(jié)果條數(shù)是兩張表的乘積。
SELECT e.ename,d.dname FROM emp e , dept d ; #會出現(xiàn)笛卡兒積現(xiàn)象(56條數(shù)據(jù))(已經(jīng)被淘汰的方式sql92寫法)
關(guān)于表別名,使用表別名有什么好處嗎?
執(zhí)行效率高
可讀性好
4.避免笛卡爾積現(xiàn)象
答:當(dāng)然是加條件了。
SELECT e.ename,d.dname FROM emp e , dept d WHERE e.deptno = d.deptno ;
思考:避免了笛卡爾積會減少記錄的匹配次數(shù)嗎?
不會,還是匹配一樣的次數(shù),但是只顯示有效條數(shù)。(并不能提高效率)
5.內(nèi)連接
1)等值連接
語法:(inner)join …on…
inner可省略,帶著只為可讀性好一些。兩張表內(nèi)連接的意思 (常用)
SELECT e.ename,d.dname FROM emp e INNER(可以省略) JOIN dept d ON e.deptno = d.deptno WHERE 過濾條件;
sql99語法:使得表的連接條件和后來的過濾條件分離了!
2)非等值連接
SELECT e.ename,e.sal,s.grade FROM emp e JOIN salgrade s ON e.sal BETWEEN s.losal AND s.hisal
sql99語法:表連接條件并不是一個確切的值!
3)自連接
最大特點:一張表看作兩張表,自己連自己
SELECT a.ename,b.mgr admin FROM emp a JOIN emp b WHERE a.mgr = b.empno ;
6.外連接
語法格式:left|right(outer)join … on …
outer可省略,帶著只為可讀性好一些。兩張表外連接的意思
左外連接(左連接):表示左邊是主表。
右外連接(右連接):表示右邊是主表。
左連接有右連接的寫法,同樣右連接也有左連接的寫法 :
案例:查詢沒有員工的部門
SELECT d.* FROM dept d LEFT JOIN emp e ON e.`DEPTNO` = d.`DEPTNO` WHERE e.`EMPNO` IS NULL
7.內(nèi)連接和外連接的區(qū)別:
內(nèi)連接:假設(shè)有AB兩張表,使用內(nèi)連接,凡是A表B表能夠匹配上的記錄查詢出來,這就是內(nèi)連接,AB兩張表并沒有主次之分,兩張表是平等的。
外連接:假設(shè)AB兩張表,使用外連接,AB兩張表中的一張是主表,一張是副表,主要查詢主表中的數(shù)據(jù),捎帶查詢副表,當(dāng)副表中的數(shù)據(jù)并沒和主表中的數(shù)據(jù)匹配上,副表自動模擬出NULL與之相匹配(主表數(shù)據(jù)無條件查詢)
8.三個表連接查詢
案例一:查詢每個員工的部門名稱和薪資等級
SELECT e.ename,d.`DNAME`,s.grade FROM emp e JOIN dept d ON e.`DEPTNO` = d.`DEPTNO` JOIN salgrade s ON e.`SAL` BETWEEN s.losal AND s.hisal
案例二:查詢每個員工的部門名稱、薪資等級、上級領(lǐng)導(dǎo)
SELECT e.`ENAME` '員工' ,d.`DNAME` '部門' , s.grade '薪資等級' , e2.ename '領(lǐng)導(dǎo)' FROM emp e JOIN dept d ON e.`DEPTNO` = d.`DEPTNO` JOIN salgrade s ON e.`SAL` BETWEEN s.losal AND hisal LEFT JOIN emp e2 ON e.`MGR` = e2.empno
到此這篇關(guān)于MySql多表鏈接查詢詳細教程的文章就介紹到這了,更多相關(guān)MySql多表鏈接查詢內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
MySQL報錯cannot?add?foreign?key?constraint的問題解決方法
這篇文章主要介紹了MySQL報錯cannot?add?foreign?key?constraint的問題解決方法,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-06-06mybatis mysql delete in操作只能刪除第一條數(shù)據(jù)的方法
這篇文章主要介紹了mybatis mysql delete in操作只能刪除第一條數(shù)據(jù)的問題及解決方法,需要的朋友可以參考下2018-09-09mysql截取的字符串函數(shù)substring_index的用法
這篇文章主要介紹了mysql截取的字符串函數(shù)substring_index的用法,需要的朋友可以參考下2014-08-08