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

超詳細(xì)mysql left join,right join,inner join用法分析

 更新時(shí)間:2008年08月05日 16:35:52   作者:  
比較詳細(xì)的mysql的幾種連接功能分析,只要你看完就能學(xué)會(huì)的好東西
下面是例子分析
表A記錄如下:
aID        aNum
1           a20050111
2           a20050112
3           a20050113
4           a20050114
5           a20050115

表B記錄如下:
bID        bName
1            2006032401
2           2006032402
3           2006032403
4           2006032404
8           2006032408

創(chuàng)建這兩個(gè)表SQL語(yǔ)句如下:
CREATE TABLE  a
aID int( 1 ) AUTO_INCREMENT PRIMARY KEY ,
aNum char( 20 )
)
CREATE TABLE b(
bID int( 1 ) NOT NULL AUTO_INCREMENT PRIMARY KEY ,
bName char( 20 ) 
)

INSERT INTO a
VALUES ( 1, 'a20050111' ) , ( 2, 'a20050112' ) , ( 3, 'a20050113' ) , ( 4, 'a20050114' ) , ( 5, 'a20050115' ) ;

INSERT INTO b
VALUES ( 1, ' 2006032401' ) , ( 2, '2006032402' ) , ( 3, '2006032403' ) , ( 4, '2006032404' ) , ( 8, '2006032408' ) ;

實(shí)驗(yàn)如下:
1.left join(左聯(lián)接)

sql語(yǔ)句如下: 
SELECT * FROM a
LEFT JOIN  b 
ON a.aID =b.bID

結(jié)果如下:
aID        aNum                   bID           bName
1            a20050111         1               2006032401
2            a20050112         2              2006032402
3            a20050113         3              2006032403
4            a20050114         4              2006032404
5            a20050115         NULL       NULL
(所影響的行數(shù)為 5 行)

結(jié)果說(shuō)明:
        left join是以A表的記錄為基礎(chǔ)的,A可以看成左表,B可以看成右表,left join是以左表為準(zhǔn)的.
換句話說(shuō),左表(A)的記錄將會(huì)全部表示出來(lái),而右表(B)只會(huì)顯示符合搜索條件的記錄(例子中為: A.aID = B.bID).
B表記錄不足的地方均為NULL.

2.right join(右聯(lián)接)

sql語(yǔ)句如下: 
SELECT  * FROM a
RIGHT JOING b 
ON a.aID = b.bID

結(jié)果如下:
aID        aNum                   bID           bName
1            a20050111         1               2006032401
2            a20050112         2              2006032402
3            a20050113         3              2006032403
4            a20050114         4              2006032404
NULL    NULL                   8              2006032408
(所影響的行數(shù)為 5 行)

結(jié)果說(shuō)明:
        仔細(xì)觀察一下,就會(huì)發(fā)現(xiàn),和left join的結(jié)果剛好相反,這次是以右表(B)為基礎(chǔ)的,A表不足的地方用NULL填充.

3.inner join(相等聯(lián)接或內(nèi)聯(lián)接)

sql語(yǔ)句如下: 
SELECT * FROM  a
INNER JOIN  b
ON a.aID =b.bID

等同于以下SQL句:
SELECT * 
FROM a,b
WHERE a.aID = b.bID

結(jié)果如下:
aID        aNum                   bID           bName
1            a20050111         1               2006032401
2            a20050112         2              2006032402
3            a20050113         3              2006032403
4            a20050114         4              2006032404

結(jié)果說(shuō)明:
        很明顯,這里只顯示出了 A.aID = B.bID的記錄.這說(shuō)明inner join并不以誰(shuí)為基礎(chǔ),它只顯示符合條件的記錄.
LEFT JOIN操作用于在任何的 FROM 子句中,

組合來(lái)源表的記錄。使用 LEFT JOIN 運(yùn)算來(lái)創(chuàng)建一個(gè)左邊外部聯(lián)接。左邊外部聯(lián)接將包含了從第一個(gè)(左邊)開(kāi)始的兩個(gè)表中的全部記錄,即
使在第二個(gè)(右邊)表中并沒(méi)有相符值的記錄。 

語(yǔ)法:FROM table1 LEFT JOIN table2 ON table1.field1 compopr table2.field2 
說(shuō)明:table1, table2參數(shù)用于指定要將記錄組合的表的名稱。
field1, field2參數(shù)指定被聯(lián)接的字段的名稱。且這些字段必須有相同的數(shù)據(jù)類型及包含相同類型的數(shù)據(jù),但它們不需要有相同的
名稱。
compopr參數(shù)指定關(guān)系比較運(yùn)算符:"=", "<", ">", "<=", ">=" 或 "<>"。
如果在INNER JOIN操作中要聯(lián)接包含Memo 數(shù)據(jù)類型或 OLE Object 數(shù)據(jù)類型數(shù)據(jù)的字段,將會(huì)發(fā)生錯(cuò)誤。

相關(guān)文章

  • MySQL創(chuàng)建數(shù)據(jù)庫(kù)的兩種方法

    MySQL創(chuàng)建數(shù)據(jù)庫(kù)的兩種方法

    這篇文章主要為大家詳細(xì)介紹了MySQL創(chuàng)建數(shù)據(jù)庫(kù)的兩種方法,感興趣的小伙伴們可以參考一下
    2016-05-05
  • mysql如何將id重新修改為遞增

    mysql如何將id重新修改為遞增

    這篇文章主要介紹了mysql如何將id重新修改為遞增,本文模擬場(chǎng)景結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-08-08
  • MySql實(shí)現(xiàn)分布式鎖詳解

    MySql實(shí)現(xiàn)分布式鎖詳解

    這篇文章主要為大家詳細(xì)介紹了如何使用本地MySql實(shí)現(xiàn)一把分布式鎖,以及Mysql實(shí)現(xiàn)分布式鎖的原理是怎么樣的,有需要的小伙伴可以了解下
    2024-11-11
  • Mysql排序的特性詳情

    Mysql排序的特性詳情

    這篇文章主要介紹Mysql排序的特性,新寫(xiě)了一個(gè)功能,自測(cè)和測(cè)試環(huán)境測(cè)試都沒(méi)問(wèn)題,但在生產(chǎn)環(huán)境會(huì)出現(xiàn)偶發(fā)問(wèn)題。于是,加班到12點(diǎn)一直排查問(wèn)題,終于定位了的問(wèn)題原因:Mysql Limit查詢優(yōu)化導(dǎo)致?,F(xiàn)抽象出問(wèn)題模型及解決方案,分析給大家,避免大家踩坑,需要的朋友可以參考一下
    2021-10-10
  • MySQL?count(*),count(id),count(1),count(字段)區(qū)別

    MySQL?count(*),count(id),count(1),count(字段)區(qū)別

    本文主要介紹了MySQL?count(*),count(id),count(1),count(字段)區(qū)別,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-05-05
  • MySQL?數(shù)據(jù)庫(kù)?增刪查改、克隆、外鍵?等操作總結(jié)

    MySQL?數(shù)據(jù)庫(kù)?增刪查改、克隆、外鍵?等操作總結(jié)

    這篇文章主要介紹了MySQL?數(shù)據(jù)庫(kù)?增刪查改、克隆、外鍵?等操作,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-05-05
  • linux正確重啟MySQL的方法

    linux正確重啟MySQL的方法

    修改了my.cnf,需要重啟MySQL服務(wù),正確重啟MYSQL方法請(qǐng)看下面的文章
    2013-11-11
  • Windows Server 2003下修改MySQL 5.5數(shù)據(jù)庫(kù)data目錄

    Windows Server 2003下修改MySQL 5.5數(shù)據(jù)庫(kù)data目錄

    這篇文章主要介紹了Windows Server 2003下修改MySQL 5.5數(shù)據(jù)庫(kù)data目錄,需要的朋友可以參考下
    2016-04-04
  • mysql授予用戶遠(yuǎn)程訪問(wèn)權(quán)限的實(shí)現(xiàn)

    mysql授予用戶遠(yuǎn)程訪問(wèn)權(quán)限的實(shí)現(xiàn)

    在默認(rèn)情況下,MySQL 數(shù)據(jù)庫(kù)僅允許在本地主機(jī)上進(jìn)行訪問(wèn),如果您需要遠(yuǎn)程連接到 MySQL 數(shù)據(jù)庫(kù),您需要授予用戶遠(yuǎn)程訪問(wèn)權(quán)限,本文就來(lái)
    2023-11-11
  • MySQL數(shù)據(jù)庫(kù)InnoDB引擎下服務(wù)器斷電數(shù)據(jù)恢復(fù)方法

    MySQL數(shù)據(jù)庫(kù)InnoDB引擎下服務(wù)器斷電數(shù)據(jù)恢復(fù)方法

    這篇文章主要介紹了MySQL數(shù)據(jù)庫(kù)InnoDB引擎下服務(wù)器斷電數(shù)據(jù)恢復(fù)方法,需要的朋友可以參考下
    2016-04-04

最新評(píng)論