婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁(yè) > 知識(shí)庫(kù) > SQL 多表連接查詢(xún)實(shí)現(xiàn)語(yǔ)句

SQL 多表連接查詢(xún)實(shí)現(xiàn)語(yǔ)句

熱門(mén)標(biāo)簽:外呼系統(tǒng)改進(jìn) 湖南電腦外呼系統(tǒng)平臺(tái) 分享百度地圖標(biāo)注多個(gè)位置 廣東防封卡外呼系統(tǒng)原理是什么 長(zhǎng)沙智能外呼系統(tǒng) 知名電銷(xiāo)機(jī)器人價(jià)格 菏澤語(yǔ)音電銷(xiāo)機(jī)器人加盟公司 電銷(xiāo)機(jī)器人公司 需要哪些牌照 地圖標(biāo)注牌
1.理論

只要兩個(gè)表的公共字段有匹配值,就將這兩個(gè)表中的記錄組合起來(lái)。

個(gè)人理解:以一個(gè)共同的字段求兩個(gè)表中符合要求的交集,并將每個(gè)表符合要求的記錄以共同的字段為牽引合并起來(lái)。

語(yǔ)法

select * FROM table1 INNER JOIN table2 ON table1 . field1 compopr table2 . field2

INNER JOIN 操作包含以下部分:

部分 說(shuō)明
table1, table2 要組合其中的記錄的表的名稱(chēng)。
field1,field2 要聯(lián)接的字段的名稱(chēng)。如果它們不是數(shù)字,則這些字段的數(shù)據(jù)類(lèi)型必須相同,并且包含同類(lèi)數(shù)據(jù),但是,它們不必具有相同的名稱(chēng)。
compopr
任何關(guān)系比較運(yùn)算符:“=”、“”、“>”、“=”、“>=”或者“>”。
     

說(shuō)明

可以在任何 FROM 子句中使用 INNER JOIN 操作。這是最常用的聯(lián)接類(lèi)型。只要兩個(gè)表的公共字段上存在相匹配的值,Inner 聯(lián)接就會(huì)組合這些表中的記錄。

可以將 INNER JOIN 用于 Departments 及 Employees 表,以選擇出每個(gè)部門(mén)的所有雇員。而要選擇所有部分(即使某些部門(mén)中并沒(méi)有被分配雇員)或者所有雇員(即使某些雇員沒(méi)有分配到任何部門(mén)),則可以通過(guò) LEFT JOIN 或者 RIGHT JOIN 操作來(lái)創(chuàng)建外部聯(lián)接。

如果試圖聯(lián)接包含備注或 OLE 對(duì)象數(shù)據(jù)的字段,將發(fā)生錯(cuò)誤。

可以聯(lián)接任何兩個(gè)相似類(lèi)型的數(shù)字字段。例如,可以聯(lián)接自動(dòng)編號(hào)和長(zhǎng)整型字段,因?yàn)樗鼈兙窍嗨祁?lèi)型。然而,不能聯(lián)接單精度型和雙精度型類(lèi)型字段。

下例展示了如何通過(guò) CategoryID 字段聯(lián)接 Categories 和 Products 表:

SELECT CategoryName, ProductName

FROM Categories INNER JOIN Products

ON Categories.CategoryID = Products.CategoryID;

在前面的示例中,CategoryID 是被聯(lián)接字段,但是它不包含在查詢(xún)輸出中,因?yàn)樗话?SELECT 語(yǔ)句中。若要包含被聯(lián)接字段,請(qǐng)?jiān)?SELECT 語(yǔ)句中包含該字段名,在本例中是指 Categories.CategoryID。

也可以在 JOIN 語(yǔ)句中鏈接多個(gè) ON 子句,請(qǐng)使用如下語(yǔ)法:

SELECT fields
FROM table1 INNER JOIN table2
ON table1.field1 compopr table2.field1 AND
ON table1.field2 compopr table2.field2 OR
ON table1.field3 compopr table2.field3;

也可以通過(guò)如下語(yǔ)法嵌套 JOIN 語(yǔ)句:

SELECT fields
FROM table1 INNER JOIN
(table2 INNER JOIN [( ]table3
[INNER JOIN [( ]tablex [INNER JOIN ...)]
ON table3.field3 compopr tablex.fieldx)]
ON table2.field2 compopr table3.field3)
ON table1.field1 compopr table2.field2;

LEFT JOIN 或 RIGHT JOIN 可以嵌套在 INNER JOIN 之中,但是 INNER JOIN 不能嵌套于 LEFT JOIN 或 RIGHT JOIN 之中。


2.操作實(shí)例

表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


實(shí)驗(yàn)如下:
1.left join

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)的.
換句話(huà)說(shuō),左表(A)的記錄將會(huì)全部表示出來(lái),而右表(B)只會(huì)顯示符合搜索條件的記錄(例子中為: A.aID = B.bID).
B表記錄不足的地方均為NULL.

2.right join
sql語(yǔ)句如下:
select * from A
right 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
NULL           NULL                          8                     2006032408
(所影響的行數(shù)為 5 行)
結(jié)果說(shuō)明:
        仔細(xì)觀察一下,就會(huì)發(fā)現(xiàn),和left join的結(jié)果剛好相反,這次是以右表(B)為基礎(chǔ)的,A表不足的地方用NULL填充.


3.inner join
sql語(yǔ)句如下:
select * from A
innerjoin 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

結(jié)果說(shuō)明:
        很明顯,這里只顯示出了 A.aID = B.bID的記錄.這說(shuō)明inner join并不以誰(shuí)為基礎(chǔ),它只顯示符合條件的記錄.   還有就是inner join 可以結(jié)合where語(yǔ)句來(lái)使用 如:    select * from A innerjoin B on A.aID = B.bID where b.bname='2006032401' 這樣的話(huà) 就只會(huì)放回一條數(shù)據(jù)了

個(gè)人總結(jié):將多張表安裝以上三種規(guī)則連接成一張表

您可能感興趣的文章:
  • SQL重復(fù)記錄查詢(xún)的幾種方法
  • sql表連接查詢(xún)使用方法(sql多表連接查詢(xún))
  • SQL 查詢(xún)語(yǔ)句積累
  • 三表左連接查詢(xún)的sql語(yǔ)句寫(xiě)法
  • SQL查詢(xún)的底層運(yùn)行原理深入分析

標(biāo)簽:美容院 珠海 西寧 天水 福建 泉州 商洛 呼和浩特

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《SQL 多表連接查詢(xún)實(shí)現(xiàn)語(yǔ)句》,本文關(guān)鍵詞  SQL,多表,連接,查詢(xún),實(shí)現(xiàn),;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《SQL 多表連接查詢(xún)實(shí)現(xiàn)語(yǔ)句》相關(guān)的同類(lèi)信息!
  • 本頁(yè)收集關(guān)于SQL 多表連接查詢(xún)實(shí)現(xiàn)語(yǔ)句的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章

    上一篇:SQL Server 高速緩存依賴(lài)分析

    下一篇:sqlserver 無(wú)法驗(yàn)證產(chǎn)品密匙的完美解決方案[測(cè)試通過(guò)]

    主站蜘蛛池模板: 齐齐哈尔市| 长汀县| 建阳市| 阆中市| 清远市| 静乐县| 五寨县| 邛崃市| 南召县| 海林市| 阜阳市| 南宁市| 铜梁县| 金湖县| 宜兴市| 临西县| 神农架林区| 永福县| 丰城市| 电白县| 巴里| 濮阳市| 敖汉旗| 防城港市| 民丰县| 黔南| 玉龙| 安龙县| 理塘县| 柳江县| 盘山县| 日土县| 勐海县| 南京市| 山东省| 原平市| 怀远县| 永仁县| 中超| 金寨县| 郑州市|