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

Mysql之left join的用法解讀

 更新時(shí)間:2025年07月15日 09:57:01   作者:秋分的秋刀魚  
文章講解了SQL左連接(LEFT JOIN)的原理,指出左表全部記錄會(huì)被保留,右表缺失時(shí)顯示為NULL,ON子句用于關(guān)聯(lián)條件,WHERE篩選左表數(shù)據(jù),實(shí)例展示了不同條件對(duì)查詢結(jié)果的影響,強(qiáng)調(diào)左連接中左表不可被過(guò)濾,右表限制需在ON中設(shè)置

簡(jiǎn)述

left JOIN:把left join左邊的表的記錄全部找出來(lái)。系統(tǒng)會(huì)先用表A和表B做個(gè)笛卡兒積,然后以表A為基表,去掉笛卡兒積中表A部分為NULL的記錄。最后形成你的結(jié)果。

進(jìn)行左連接時(shí),就有涉及到主表、輔表,這時(shí)主表?xiàng)l件寫在WHERE之后,輔表?xiàng)l件寫在ON后面。

實(shí)例

1、表a結(jié)構(gòu)和數(shù)據(jù)

table a(id, type):
id     type 
----------------------------------
1      1         
2      1          
3      2     

2、表b結(jié)構(gòu)和數(shù)據(jù)

table b(id, class):
id    class 
---------------------------------
1      1
2      2

SQL語(yǔ)句調(diào)用

sql語(yǔ)句1

select a.*, b.* from a left join b on a.id = b.id and a.type = 1;

執(zhí)行結(jié)果為:

a.id    a.type    b.id    b.class
---------------------------------------
1        1            1        1
2        1            2        2
3        2         

sql語(yǔ)句2

select a.*, b.* from a left join b on a.id = b.id where a.type = 1;

執(zhí)行結(jié)果為:

a.id    a.type    b.id    b.class
----------------------------------------
1        1            1        1
2        1            2        2

sql語(yǔ)句3

select a.*, b.* from a left join b on a.id = b.id and b.class = 1;

執(zhí)行結(jié)果為:

a.id    a.type    b.id    b.class
----------------------------------------
1        1            1        1
2        1            
3        2          

總結(jié)

sql語(yǔ)句1可見,left join 中左表的全部記錄將全部被查詢顯示,on 后面的條件對(duì)它不起作用,除非再后面再加上where來(lái)進(jìn)行篩選,這就是sql語(yǔ)句2了。

sql語(yǔ)句3可見,on后面的條件中,右表的限制條件將會(huì)起作用。

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • JMeter壓測(cè)Mysql教程分享

    JMeter壓測(cè)Mysql教程分享

    文章介紹了如何使用JMeter進(jìn)行數(shù)據(jù)庫(kù)壓力測(cè)試的步驟,包括安裝JMeter、下載并配置MySQL JDBC驅(qū)動(dòng)、設(shè)置測(cè)試計(jì)劃、添加JDBC連接配置元件、添加JDBC請(qǐng)求取樣器以及可選的監(jiān)聽器配置,最后,文章指導(dǎo)如何運(yùn)行測(cè)試并分析結(jié)果,以評(píng)估數(shù)據(jù)庫(kù)在不同壓力下的性能表現(xiàn)
    2024-11-11
  • mysql命令行愛(ài)好者必備工具mycli

    mysql命令行愛(ài)好者必備工具mycli

    這篇文章主要介紹了mysql命令行愛(ài)好者必備工具mycli的相關(guān)知識(shí),非常不錯(cuò),具有一定的參考借鑒價(jià)值 ,需要的朋友可以參考下
    2019-05-05
  • mysql中異常錯(cuò)誤ERROR:2002的解決方法

    mysql中異常錯(cuò)誤ERROR:2002的解決方法

    最近在啟動(dòng)mysql的時(shí)候發(fā)現(xiàn)mysql報(bào)錯(cuò)了,錯(cuò)誤代碼是2002,通過(guò)查找相關(guān)的資料發(fā)現(xiàn)是var/lib/mysql 的訪問(wèn)權(quán)限問(wèn)題,所以這篇文章主要介紹了mysql中異常錯(cuò)誤ERROR:2002的解決方法,需要的朋友可以參考借鑒,下面來(lái)一起看看吧。
    2017-03-03
  • 如何使用Maxwell實(shí)時(shí)同步mysql數(shù)據(jù)

    如何使用Maxwell實(shí)時(shí)同步mysql數(shù)據(jù)

    這篇文章主要介紹了如何使用Maxwell實(shí)時(shí)同步mysql數(shù)據(jù),幫助大家更好的理解和學(xué)習(xí)使用MySQL,感興趣的朋友可以了解下
    2021-04-04
  • MySQL中?LBCC?和?MVCC?的理解及常見問(wèn)題示例

    MySQL中?LBCC?和?MVCC?的理解及常見問(wèn)題示例

    這篇文章主要介紹了MySQL中LBCC和MVCC的理解及常見問(wèn)題示例,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,感興趣的朋友可以參考一下
    2022-09-09
  • mysql查詢昨天 一周前 一月前 一年前的數(shù)據(jù)

    mysql查詢昨天 一周前 一月前 一年前的數(shù)據(jù)

    這篇文章主要介紹了mysql查詢昨天 一周前 一月前 一年前的數(shù)據(jù)的方法,需要的朋友可以參考下
    2014-05-05
  • MySQL SHOW 命令的使用介紹

    MySQL SHOW 命令的使用介紹

    MySQL SHOW 命令的使用介紹,使用mysql的朋友可以參考下。
    2011-08-08
  • MySQL慢查詢的坑

    MySQL慢查詢的坑

    這篇文章主要介紹了MySQL慢查詢的坑,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2021-04-04
  • mysql之如何把查詢的結(jié)果保存到新表

    mysql之如何把查詢的結(jié)果保存到新表

    這篇文章主要介紹了mysql之如何把查詢的結(jié)果保存到新表問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-07-07
  • 一文教你在windows中如何同時(shí)安裝兩個(gè)不同版本的Mysql

    一文教你在windows中如何同時(shí)安裝兩個(gè)不同版本的Mysql

    在項(xiàng)目中可能會(huì)用到多個(gè)版本的Mysql數(shù)據(jù)庫(kù),本文將和大家介紹一下如何在本機(jī)已安裝了一個(gè)MySQL?5.7.38的情況下,再安裝一個(gè)mysql?8.0版本吧
    2025-03-03

最新評(píng)論