當前位置:首頁 » 編程語言 » sql外聯

sql外聯

發布時間: 2022-07-04 14:25:19

sql的內部連接和外部連接到底有什麼區別啊

SQL--JOIN之完全用法

外聯接。外聯接可以是左向外聯接、右向外聯接或完整外部聯接。
在 FROM 子句中指定外聯接時,可以由下列幾組關鍵字中的一組指定:

LEFT JOIN 或 LEFT OUTER JOIN。
左向外聯接的結果集包括 LEFT OUTER 子句中指定的左表的所有行,而不僅僅是聯接列所匹配的行。如果左表的某行在右表中沒有匹配行,則在相關聯的結果集行中右表的所有選擇列表列均為空值。

RIGHT JOIN 或 RIGHT OUTER JOIN。
右向外聯接是左向外聯接的反向聯接。將返回右表的所有行。如果右表的某行在左表中沒有匹配行,則將為左表返回空值。

FULL JOIN 或 FULL OUTER JOIN。
完整外部聯接返回左表和右表中的所有行。當某行在另一個表中沒有匹配行時,則另一個表的選擇列表列包含空值。如果表之間有匹配行,則整個結果集行包含基表的數據值。

僅當至少有一個同屬於兩表的行符合聯接條件時,內聯接才返回行。內聯接消除與另一個表中的任何行不匹配的行。而外聯接會返回 FROM 子句中提到的至少一個表或視圖的所有行,只要這些行符合任何 WHERE 或 HAVING 搜索條件。將檢索通過左向外聯接引用的左表的所有行,以及通過右向外聯接引用的右表的所有行。完整外部聯接中兩個表的所有行都將返回。

Microsoft® SQL Server™ 2000 對在 FROM 子句中指定的外聯接使用以下 SQL-92 關鍵字:

LEFT OUTER JOIN 或 LEFT JOIN

RIGHT OUTER JOIN 或 RIGHT JOIN

FULL OUTER JOIN 或 FULL JOIN
SQL Server 支持 SQL-92 外聯接語法,以及在 WHERE 子句中使用 *= 和 =* 運算符指定外聯接的舊式語法。由於 SQL-92 語法不容易產生歧義,而舊式 Transact-SQL 外聯接有時會產生歧義,因此建議使用 SQL-92 語法。

使用左向外聯接
假設在 city 列上聯接 authors 表和 publishers 表。結果只顯示在出版商所在城市居住的作者(本例中為 Abraham Bennet 和 Cheryl Carson)。

若要在結果中包括所有的作者,而不管出版商是否住在同一個城市,請使用 SQL-92 左向外聯接。下面是 Transact-SQL 左向外聯接的查詢和結果:

USE pubs
SELECT a.au_fname, a.au_lname, p.pub_name
FROM authors a LEFT OUTER JOIN publishers p
ON a.city = p.city
ORDER BY p.pub_name ASC, a.au_lname ASC, a.au_fname ASC

下面是結果集:

au_fname au_lname pub_name
-------------------- ------------------------------ -----------------
Reginald Blotchet-Halls NULL
Michel DeFrance NULL
Innes del Castillo NULL
Ann Dull NULL
Marjorie Green NULL
Morningstar Greene NULL
Burt Gringlesby NULL
Sheryl Hunter NULL
Livia Karsen NULL
Charlene Locksley NULL
Stearns MacFeather NULL
Heather McBadden NULL
Michael O'Leary NULL
Sylvia Panteley NULL
Albert Ringer NULL
Anne Ringer NULL
Meander Smith NULL
Dean Straight NULL
Dirk Stringer NULL
Johnson White NULL
Akiko Yokomoto NULL
Abraham Bennet Algodata Infosystems
Cheryl Carson Algodata Infosystems

(23 row(s) affected)

不管是否與 publishers 表中的 city 列匹配,LEFT OUTER JOIN 均會在結果中包含 authors 表的所有行。注意:結果中所列的大多數作者都沒有相匹配的數據,因此,這些行的 pub_name 列包含空值。

使用右向外聯接
假設在 city 列上聯接 authors 表和 publishers 表。結果只顯示在出版商所在城市居住的作者(本例中為 Abraham Bennet 和 Cheryl Carson)。SQL-92 右向外聯接運算符 RIGHT OUTER JOIN 指明:不管第一個表中是否有匹配的數據,結果將包含第二個表中的所有行。

若要在結果中包括所有的出版商,而不管城市中是否還有出版商居住,請使用 SQL-92 右向外聯接。下面是 Transact-SQL 右向外聯接的查詢和結果:

USE pubs
SELECT a.au_fname, a.au_lname, p.pub_name
FROM authors AS a RIGHT OUTER JOIN publishers AS p
ON a.city = p.city
ORDER BY p.pub_name ASC, a.au_lname ASC, a.au_fname ASC

下面是結果集:

au_fname au_lname pub_name
-------------------- ------------------------ --------------------
Abraham Bennet Algodata Infosystems
Cheryl Carson Algodata Infosystems
NULL NULL Binnet & Hardley
NULL NULL Five Lakes Publishing
NULL NULL GGG&G
NULL NULL Lucerne Publishing
NULL NULL New Moon Books
NULL NULL Ramona Publishers
NULL NULL Scootney Books

(9 row(s) affected)

使用謂詞(如將聯接與常量比較)可以進一步限制外聯接。下例包含相同的右向外聯接,但消除銷售量低於 50 本的書籍的書名:

USE pubs
SELECT s.stor_id, s.qty, t.title
FROM sales s RIGHT OUTER JOIN titles t
ON s.title_id = t.title_id
AND s.qty > 50
ORDER BY s.stor_id ASC

下面是結果集:

stor_id qty title
------- ------ ---------------------------------------------------------
(null) (null) But Is It User Friendly?
(null) (null) Computer Phobic AND Non-Phobic Indivials: Behavior
Variations
(null) (null) Cooking with Computers: Surreptitious Balance Sheets
(null) (null) Emotional Security: A New Algorithm
(null) (null) Fifty Years in Buckingham Palace Kitchens
7066 75 Is Anger the Enemy?
(null) (null) Life Without Fear
(null) (null) Net Etiquette
(null) (null) Onions, Leeks, and Garlic: Cooking Secrets of the
Mediterranean
(null) (null) Prolonged Data Deprivation: Four Case Studies
(null) (null) Secrets of Silicon Valley
(null) (null) Silicon Valley Gastronomic Treats
(null) (null) Straight Talk About Computers
(null) (null) Sushi, Anyone?
(null) (null) The Busy Executive's Database Guide
(null) (null) The Gourmet Microwave
(null) (null) The Psychology of Computer Cooking
(null) (null) You Can Combat Computer Stress!

(18 row(s) affected)

有關謂詞的更多信息,請參見 WHERE。

使用完整外部聯接
若要通過在聯接結果中包括不匹配的行保留不匹配信息,請使用完整外部聯接。Microsoft® SQL Server™ 2000 提供完整外部聯接運算符 FULL OUTER JOIN,不管另一個表是否有匹配的值,此運算符都包括兩個表中的所有行。

假設在 city 列上聯接 authors 表和 publishers 表。結果只顯示在出版商所在城市居住的作者(本例中為 Abraham Bennet 和 Cheryl Carson)。SQL-92 FULL OUTER JOIN 運算符指明:不管表中是否有匹配的數據,結果將包括兩個表中的所有行。

若要在結果中包括所有作者和出版商,而不管城市中是否有出版商或者出版商是否住在同一個城市,請使用完整外部聯接。下面是 Transact-SQL 完整外部聯接的查詢和結果:

USE pubs
SELECT a.au_fname, a.au_lname, p.pub_name
FROM authors a FULL OUTER JOIN publishers p
ON a.city = p.city
ORDER BY p.pub_name ASC, a.au_lname ASC, a.au_fname ASC

下面是結果集:

au_fname au_lname pub_name
-------------------- ---------------------------- --------------------
Reginald Blotchet-Halls NULL
Michel DeFrance NULL
Innes del Castillo NULL
Ann Dull NULL
Marjorie Green NULL
Morningstar Greene NULL
Burt Gringlesby NULL
Sheryl Hunter NULL
Livia Karsen NULL
Charlene Locksley NULL
Stearns MacFeather NULL
Heather McBadden NULL
Michael O'Leary NULL
Sylvia Panteley NULL
Albert Ringer NULL
Anne Ringer NULL
Meander Smith NULL
Dean Straight NULL
Dirk Stringer NULL
Johnson White NULL
Akiko Yokomoto NULL
Abraham Bennet Algodata Infosystems
Cheryl Carson Algodata Infosystems
NULL NULL Binnet & Hardley
NULL NULL Five Lakes Publishing
NULL NULL GGG&G
NULL NULL Lucerne Publishing
NULL NULL New Moon Books
NULL NULL Ramona Publishers
NULL NULL Scootney Books

(30 row(s) affected)

Ⅱ SQL的內部聯合和外部聯合怎麼用啊

/*sql內聯接,外聯接演示*/
--1 定義一個員工表,一個部門表
DECLARE @emp TABLE(編號 varchar(8),名稱 varchar(10),部門編號 varchar(8))
DECLARE @dept table(編號 varchar(8),名稱 varchar(10))
--2 插入演示數據,注意客服部是沒有員工的
insert into @dept select '001','人事部'
union select '002','銷售部'
union select '003','客服部'
insert into @emp select 1,'員工1','001'
union select 2,'員工2','001'
union select 3,'員工3','002'
union select 4,'員工4','002'
union select 5,'員工5','002'
union select 6,'員工6','002'
--select * from @dept
--select * from @emp
---內聯接:inner join, 員工表有六行,就返回六行
--select d.名稱,e.名稱 as 員工姓名,e.編號 as 員工編號
-- from @dept as d INNER JOIN @emp as e on e.部門編號=d.編號
---左外聯接:包括左表(在這里是部門表)中的所有行,關聯不到的一律顯示為null ,共七行,客服部是null
select d.名稱,e.名稱 as 員工姓名,e.編號 as 員工編號
from @dept as d LEFT JOIN @emp as e on e.部門編號=d.編號
select d.名稱,e.名稱 as 員工姓名,e.編號 as 員工編號
from @emp as e LEFT JOIN @dept as d on e.部門編號=d.編號
--在外聯接,包含右表中符合條件的所有行,僅返回員工表(右表)中的六行
--select d.名稱,e.名稱 as 員工姓名,e.編號 as 員工編號
-- from @dept as d RIGHT JOIN @emp as e on e.部門編號=d.編號

Ⅲ SQL內聯接和外聯接的區別什麼時候用怎麼用

內連接只產生所有表中存在匹配的記錄,最常見的就是我們常用的where語句連接,兩邊的表返回的都是匹配的記錄;
外連接是不對稱連接,分為左聯接和右聯接,應該說他們的語法都是一樣的,只是一個左,一個右,結果是:相匹配的左(右)部的表的記錄 _都_ 出現在結果集中,而另一部分(滿足前一條原則下)有匹配顯示記錄,無匹配則是顯示NULL,可以用where過濾不是null的 或 是null的,相當於只滿足一邊返回匹配值;
個人認為連接過程也是一個查詢過程。

Ⅳ SQL內連接與外連接的區別

SQL內連接與外連接的共有3點不同:

1、兩者的分類不同:內連接分為相等連接和自然連接兩種連接方式;而外連接分為左外連接、右外連接和全外連接三種連接方式(左外連接即LEFT OUTER JOIN;右外連接即RIGHT OUTER JOIN)。

2、兩者所連接的對象表不同:內連接進行連接的兩個表是對應的相匹配的欄位完全相同的。左外連接中進行連接的兩個表會返回左邊表中的所有的行和右邊表中與之相匹配的列值,沒有相匹配的用空值代替。右外連接中進行連接的兩個表會返回右邊表中的所有的行和左邊表中與之相匹配的列值,沒有相匹配的用空值代替。

3、兩者的作用范圍不同:內連接的連接發生在一張基表內,而外連接的連接發生在兩張表之間。

註:內連接(典型的連接運算,使用像 = 或 <> 之類的比較運算符)。包括相等連接和自然連接。內連接使用比較運算符根據每個表共有的列的值匹配兩個表中的行。例如,檢索 students和courses表中學生標識號相同的所有行。

Ⅳ sql中內聯 和外聯是什麼意思,光看書太死板了,

連接分為:內連接、外連接、交叉連接
一、內連接--最常用
定義:僅將兩個表中滿足連接條件的行組合起來作為結果集。
在內連接中,只有在兩個表中匹配的行才能在結果集中出現
關鍵詞:INNER
JOIN
格式:SELECT
列名表
FROM
表名1
[INNER]
JOIN
表名2
ON或WHERE
條件表達式
說明:
(1)列名表中的列名可以出自後面的兩個表,但如果兩個表中有同名列,應在列名前標明出處,格式為:表名.列名
(2)若連接的兩個表名字太長,可以為它們起個別名。
格式為:表名
AS
別名
(3)INNER是默認方式,可以省略
二、外連接
1、左(外)連接
定義:在內連接的基礎上,還包含左表中所有不符合條件的數據行,並在其中的右表列填寫NULL
關鍵字:LEFT
JOIN
2、右(外)連接
定義:在內連接的基礎上,還包含右表中所有不符合條件的數據行,並在其中的左表列填寫NULL
關鍵字:RIGHT
JOIN
3、完全連接
定義:在內連接的基礎上,還包含兩個表中所有不符合條件的數據行,並在其中的左表、和右表列填寫NULL
關鍵字:FULL
JOIN
三、交叉連接
定義:將兩個表的所有行進行組合,連接後的行數為兩個表的乘積數。(笛卡爾積)
關鍵詞:CROSS
JOIN
格式:FROM
表名1
CROSS
JOIN
表名2

Ⅵ 關於SQL文的外聯接的條件

IFEXISTS
(
SELECT1
FROM[圖書表]
WHERE[在庫狀態]=1
ANDNOTEXISTS
(
SELECT1FROM[明細表]WHERE[圖書名稱]=[圖書表].[圖書名稱]
)
)
BEGIN
--這里就是"不存在"的處理過程
END

Ⅶ sql內聯和外聯的區別

比如A表
id value
1 'abc'
2 'def'
B表
id data
1 '123'
3 '456'
內聯:
select a.id aid,a.value,b.id bid,b.data from a inner join b on a.id = b.id
aid value bid data
1 'abc' 1 '123'
外聯:
select a.id aid,a.value,b.id bid,b.data from a left outer join b on a.id = b.id
aid value bid data
1 'abc' 1 '123'
2 'def' null null

Ⅷ SQL的內聯接和外聯接

Table1
No1 SName
01 張三
02 李四
03 王五
Table2
No2 Score
01 80
02 98
04 89
內聯接:兩個表存在主外鍵關系時常用內聯接查詢。
SELECT * FROM Table1 INNER JOIN Table2 ON No1=No2
左外聯接:結果包括左表的所有行,如果左表的行在右表中沒有匹配的行,則為
空值
SELECT * FROM Table1 LEFT (OUTER可省) JOIN Table2 ON No1=No2
右外聯接:和左外聯接相反
SELECT * FROM Table1 RIGHT JOIN Table2 ON No1=No2
完全外聯接:返回左表和右表中的所有行(FULL JOIN)
交叉聯接:返回的行數是左表與右錶行數的乘積(CROSS JOIN)

自己試一下就明白了

Ⅸ 請講解SQL資料庫中左外聯和右外聯的區別

外聯接。外聯接可以是左向外聯接、右向外聯接或完整外部聯接。
在 FROM 子句中指定外聯接時,可以由下列幾組關鍵字中的一組指定:

LEFT JOIN 或 LEFT OUTER JOIN。
左向外聯接的結果集包括 LEFT OUTER 子句中指定的左表的所有行,而不僅僅是聯接列所匹配的行。如果左表的某行在右表中沒有匹配行,則在相關聯的結果集行中右表的所有選擇列表列均為空值。

RIGHT JOIN 或 RIGHT OUTER JOIN。
右向外聯接是左向外聯接的反向聯接。將返回右表的所有行。如果右表的某行在左表中沒有匹配行,則將為左表返回空值。

FULL JOIN 或 FULL OUTER JOIN。
完整外部聯接返回左表和右表中的所有行。當某行在另一個表中沒有匹配行時,則另一個表的選擇列表列包含空值。如果表之間有匹配行,則整個結果集行包含基表的數據值。
例子:
a表 id name b表 id job parent_id
1 張3 1 23 1
2 李四 2 34 2
3 王武 3 34 4

a.id同parent_id 存在關系
左連接

select a.*,b.* from a left join b on a.id=b.parent_id

結果是
1 張3 1 23 1
2 李四 2 34 2
3 王武 null
右連接
select a.*,b.* from a right join b on a.id=b.parent_id

結果是
1 張3 1 23 1
2 李四 2 34 2
null 3 34 4

完全連接

select a.*,b.* from a full join b on a.id=b.parent_id

結果是
1 張3 1 23 1
2 李四 2 34 2
null 3 34 4
3 王武 null

Ⅹ 請問SQL語句中的左外聯和右外聯的區別,如何分清左表右表

左表和右表,挺好分的。就是放在關鍵字jion的左邊的表是左表,右表的是右表

from
A
inner
join
B
on
A是左表
B是右邊
左外聯和右外聯的區別,其實是互補的,
也是就A左外聯B表,反過來等價於B右外聯左邊。如
from
A
left
inner
jion
B
from
B
right
inner
jion
A
左外聯和右外聯。就是讓取左表(右表)的所有數據,同時查出右表(左表)相關聯的數據,沒相關數據
的用null補
舉例說明
學生表,考試成績表
from
student
left
jion
Result
結果查出所有學生,和對應的成績。但是可能有學生沒參加考試,所以對應的Result為null,表示缺考。

熱點內容
手機緩存的視頻怎麼看 發布:2024-04-27 00:11:05 瀏覽:57
shell腳本平方計算公式 發布:2024-04-26 23:29:26 瀏覽:187
比較實惠的雲伺服器 發布:2024-04-26 23:24:57 瀏覽:974
怎麼增加電腦緩存 發布:2024-04-26 23:23:46 瀏覽:451
android調試gdb 發布:2024-04-26 23:22:27 瀏覽:99
androidsocket服務 發布:2024-04-26 22:49:53 瀏覽:980
python編譯時加密 發布:2024-04-26 22:49:20 瀏覽:246
買車看哪些配置參數 發布:2024-04-26 22:45:50 瀏覽:835
linux顯示圖像 發布:2024-04-26 22:45:41 瀏覽:493
flash腳本格式 發布:2024-04-26 22:43:41 瀏覽:452