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

Mysql之left join的用法解讀

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

簡述

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

進(jìn)行左連接時,就有涉及到主表、輔表,這時主表?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語句調(diào)用

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

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

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

相關(guān)文章

  • JMeter壓測Mysql教程分享

    JMeter壓測Mysql教程分享

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

    mysql命令行愛好者必備工具mycli

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

    mysql中異常錯誤ERROR:2002的解決方法

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

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

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

    MySQL中?LBCC?和?MVCC?的理解及常見問題示例

    這篇文章主要介紹了MySQL中LBCC和MVCC的理解及常見問題示例,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價值,感興趣的朋友可以參考一下
    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慢查詢的坑,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-04-04
  • mysql之如何把查詢的結(jié)果保存到新表

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

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

    一文教你在windows中如何同時安裝兩個不同版本的Mysql

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

最新評論