欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MySql多表鏈接查詢詳細教程

 更新時間:2022年10月20日 08:40:48   作者:腹白  
這篇文章主要介紹了MySql多表鏈接查詢詳細教程的相關(guān)資料,需要的朋友可以參考下

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之批量插入的4種方案總結(jié)

    MySQL之批量插入的4種方案總結(jié)

    這篇文章主要介紹了MySQL之批量插入的4種方案總結(jié),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-05-05
  • MySQL建表語句基礎(chǔ)及示例詳解

    MySQL建表語句基礎(chǔ)及示例詳解

    在數(shù)據(jù)庫中,創(chuàng)建表格是存儲和組織數(shù)據(jù)的基本操作之一,下面這篇文章主要給大家介紹了關(guān)于MySQL建表語句基礎(chǔ)及示例的相關(guān)資料,文中通過代碼介紹的非常詳細,需要的朋友可以參考下
    2024-07-07
  • MySQL報錯cannot?add?foreign?key?constraint的問題解決方法

    MySQL報錯cannot?add?foreign?key?constraint的問題解決方法

    這篇文章主要介紹了MySQL報錯cannot?add?foreign?key?constraint的問題解決方法,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-06-06
  • Mysql閃退問題圖文解決辦法

    Mysql閃退問題圖文解決辦法

    之前在使用MySQL 5.5 Command Line Client時,無論輸入什么密碼,都出現(xiàn)閃退的情況,糾結(jié)了半天才找到原因,下面小編給大家分享我的解決方法,感興趣的朋友一起看看吧
    2016-11-11
  • 清理MySQL Binlog二進制日志的三種方式

    清理MySQL Binlog二進制日志的三種方式

    Binlog日志非常重要,但是占用的磁盤空間也很大,我們也需要定期的去清理二進制日志,在MySQL數(shù)據(jù)庫中,提供了自動清理Binlog日志的參數(shù),本文給大家介紹了清理MySQL Binlog二進制日志的三種方式,文中通過代碼講解非常詳細,需要的朋友可以參考下
    2024-01-01
  • Mysql事務(wù)隔離級別原理實例解析

    Mysql事務(wù)隔離級別原理實例解析

    這篇文章主要介紹了Mysql事務(wù)隔離級別原理實例解析,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-03-03
  • php中如何將圖片儲存在數(shù)據(jù)庫里

    php中如何將圖片儲存在數(shù)據(jù)庫里

    php中如何將圖片儲存在數(shù)據(jù)庫里...
    2007-03-03
  • mybatis mysql delete in操作只能刪除第一條數(shù)據(jù)的方法

    mybatis mysql delete in操作只能刪除第一條數(shù)據(jù)的方法

    這篇文章主要介紹了mybatis mysql delete in操作只能刪除第一條數(shù)據(jù)的問題及解決方法,需要的朋友可以參考下
    2018-09-09
  • mysql踩坑之count distinct多列問題

    mysql踩坑之count distinct多列問題

    這篇文章主要介紹了mysql踩坑之count distinct多列問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-03-03
  • mysql截取的字符串函數(shù)substring_index的用法

    mysql截取的字符串函數(shù)substring_index的用法

    這篇文章主要介紹了mysql截取的字符串函數(shù)substring_index的用法,需要的朋友可以參考下
    2014-08-08

最新評論