自然連接(NATURAL JOIN)

自然連接(NATURAL JOIN)是一種特殊的等價連接,它將表中具有相同名稱的列自動進行記錄匹配。自然連接不必指定任何同等連接條件。圖9.9給出了典型的自然連接示意圖。

??
圖9.9? 自然連接

自然連接自動判斷相同名稱的列,而后形成匹配。缺點是,雖然可以指定查詢結果包括哪些列,但不能人為地指定哪些列被匹配。另外,自然連接的一個特點是連接后的結果表中匹配的列只有一個,如圖9.9所示,在自然連接后的表中,只有一列C。

實例6? 使用NATURAL JOIN進行查詢

從STUDENT表和TEACHER表中查詢學生姓名、所在系、所修的本系教師開設的課程的課程號以及開課教師姓名。這時候就可以采用NATURAL JOIN對兩個表進行自然連接。實例代碼:

SELECT ??SNAME, DNAME, CNO, TNAME
FROM ??STUDENT NATURAL JOIN TEACHER

當DBMS執行查詢時,將把來自STUDENT表的行與來自TEACHER表中的行通過CNO和DNAME列進行匹配連接。即只有兩個表中的CNO和DNAME列的值都相等的行,才連接起來,作為結果表中的行,而CNO和DNAME列在結果表中只出現一次,因此在查詢時就不需指明TEACHER.DNAME或是STUDENT.DNAME。

注意?有些DBMS產品,如SQL Server,不支持NATURAL JOIN連接符,因此這里無法給出該實例代碼的運行結果。

事實上,使用NATURAL JOIN運算符進行自然連接,與檢查兩個源表中同名列值相等的WHERE子句是等價的。因此,上例的實現也可表示如下。

SELECT ??SNAME, S.DNAME, S.CNO, TNAME
FROM ??STUDENT AS S, TEACHER AS T
WHERE??S.DNAME = T.DNAME
AND???S.CNO = T.CNO

運行結果如圖9.10所示:

?
圖9.10? 另一種自然連接的查詢結果

與自然連接不同,采用這種方式進行表的連接,雖然兩表的CNO和DNAME列相等,但它們在結果表中出現了兩次,因此在SELECT語句中,如果要查詢這兩個字段,必須指明是哪個表的字段。

事實上,使用基于WHERE子句的等值連接要比使用NATURAL JOIN運算符進行自然連接要靈活得多。正如前面介紹的,使用NATURAL JOIN運算符自動判斷出具有相同名稱的列,而后形成匹配,不能人為地指定哪些列被匹配。當自然連接STUDENT表和TEACHER表時,CNO和DNAME列同時被匹配,而不能只匹配一列。而使用WHERE子句則可以實現任意列的匹配。

實例7? 使用WHERE子句進行等值連接查詢

從STUDENT表和TEACHER表中查詢學生姓名、所在系、所修的所有課程的課程號以及開課教師姓名。這時,STUDENT表和TEACHER表只需將CNO字段匹配即可。實例代碼:

SELECT ??SNAME, S.DNAME, S.CNO, TNAME
FROM ??STUDENT AS S, TEACHER AS T
WHERE??S.CNO = T.CNO
ORDER BY??SNAME

運行結果如圖9.11所示。

?
圖9.11? STUDENT表和TEACHER表匹配CNO字段的查詢結果

在這種情況下,就不可能使用NATURAL JOIN運算符實現。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/273454.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/273454.shtml
英文地址,請注明出處:http://en.pswp.cn/news/273454.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

iis express8 自動關閉

引用:http://www.cnblogs.com/chunCui/p/3522619.html 問題:最近使用vs2013開發個web , 每次調試結束時iis express 8 也會自動關閉 解決方法:web項目-屬性-web-調試器-只選中ASP.Net就可以了 轉載于:https://www.cnblogs.com/qqq…

自連接

9.3 表的連接類型 9.3.1 自連接 自連接是指表與其自身進行連接,這就需要用到前面介紹的表別名。下面通過一個具體實例來講解自連接的應用。 實例5 自連接的使用方法 查詢成績中存在不及格課程的學生的姓名、所在系、所有的課程及成績信息。如果采用前面介紹的…

從此記錄

從此記錄工作、學習、生活的那些事兒!轉載于:https://www.cnblogs.com/alwaysjava/p/4221362.html

LIKE運算符

6.5 使用LIKE進行模糊查詢 當只知道部分字符串時,可使用LIKE運算符來查詢數據庫,找出與其相關的整個字符串。因此,當把關鍵字LIKE用在WHERE子句中時,可以比較兩個字符串的部分匹配。當對字符串內容有些印象,但并不知…

AND運算符

6.2 組合查詢條件 在前一章提到的WHERE子句進行查詢時,WHERE子句后面的搜索條件只是單一的。實際上,可以通過布爾運算符AND和OR,將多個單獨的搜索條件結合在一個WHERE子句中,形成一個復合的搜索條件。當對復合搜索條件求值時&a…

Cron表達式【一】

Cron表達式【一】 Cron表達式被用來配置CronTrigger實例。 Cron表達式是一個由 7個子表達式組成的字符串。每個子表達式都描述了一個單獨的日程細節。這些子表達式用空格分隔,分別表示: 1. Seconds 秒 2. Minutes 分鐘 3. Hours 小時 4. Day-of-Month 月…

OR運算符

6.2.2 OR運算符 OR運算符表示“或”的關系。當可能有多個條件為True,但只要有一個為True就滿足搜索要求時,可以使用OR運算符來組合搜索條件。OR在結合兩個布爾表達式時,只要其中一個條件為True時,便傳回True。OR運算符的真值表…

Java基礎---網絡編程

第一講 概述 1、網絡模型:OSI參考模型和TCP/IP參考模型 圖示: 一般來說開發處于傳輸層和網際層,應用層為:FTP和HTTP協議等,傳輸層為:UDP和TCP等,網際層為:IP。 通常用戶操作的是…

AND、OR運算符的組合使用

6.2.3 AND、OR運算符的組合使用 在WHERE子句中,通過AND、OR運算符可以同時連接多個條件,當然AND、OR運算符也可以同時使用。但是當AND、OR運算符同時存在時,其優先級如何確定呢?與大多數語言一樣,SQL語言認為AND運算…

Nginx配置指定媒體類型文件強制下載

由于業務需要,在點擊顯示鏈接(如www.xxx.com/2015-01-15/xxx.png)顯示媒體資源(如圖片、視頻、音頻、文檔),而在點擊下載鏈接(如www.xxx.com/2015-01-15/xxx.png?downloadtrue)請求…

IN運算符的使用

6.3 IN運算符 在查詢中,有時只要滿足多個條件中的一個條件即可,如查詢地址在北京、上海或者重慶的學生信息,這時候可以使用IN運算符。 6.3.1 IN運算符的使用 IN運算符允許根據一行記錄中,是否有一列包括在一系列值之中&#…

app后端設計(php)

來源:http://blog.csdn.net/column/details/mobilebackend.html?page1 做了3年app相關的系統架構,api設計,先后在3個創業公司中工作,經歷過手機網頁端,android客戶端,iphone客戶端,現在從事日p…

NOT運算符與運算符

6.4.2 NOT運算符與<>運算符 對于簡單的條件查詢&#xff0c;NOT運算符與<>運算符的功能幾乎沒有什么區別&#xff0c;那么NOT運算符的優勢體現在哪里呢&#xff1f;答案是它可以與其他運算符組合使用&#xff0c;這一點是<>運算符所不能實現的。在6.4.1節已…

bootstrap-wysiwyg 結合 base64 解碼 .net bbs 圖片操作類 (三) 圖片裁剪

官方的例子 是 長方形的。 我這里 用于 正方形的頭像 所以 做如下 修改 #preview-pane .preview-container {width: 73px;height: 73px;overflow: hidden;} 可惜很莫名奇妙的是 有的時候 他自動把圖片 變小了&#xff0c;而且針對的都是 小圖&#xff0c;大圖 都顯示正常 發現…

“%”通配符

6.5.2 “%”通配符 在SQL語言中最常用的通配符可能就是“%”了&#xff0c;它表示任意字符的匹配&#xff0c;且不計字符的多少。下面通過幾個典型實例來說明“%”通配符的使用。 1&#xff0e;開頭&#xff0f;結尾匹配 從COURSE表中查詢所有以“計算機”開頭的所有課程的…

Wireshark基本介紹和學習TCP三次握手

Wireshark基本介紹和學習TCP三次握手 原文&#xff1a;http://www.cnblogs.com/TankXiao/archive/2012/10/10/2711777.html wireshark介紹 wireshark的官方下載網站&#xff1a; http://www.wireshark.org/ wireshark是非常流行的網絡封包分析軟件&#xff0c;功能十分強大。可…

“_”通配符

6.5.3 “_”通配符 “_”通配符的功能與“%”通配符基本相同&#xff0c;只是它只表示任意一個字符的匹配。當然&#xff0c;要表示兩個字符的匹配&#xff0c;就需要使用兩個“_”通配符&#xff0c;即寫成“__”。 只有在用戶確定所要查詢的字符串的個數&#xff0c;只是不…

“[]”通配符

6.5.4 “[]”通配符 “[]”通配符用于指定一系列的字符&#xff0c;只要滿足這些字符其中之一&#xff0c;且位置出現在“[]”通配符的位置的字符串就滿足查詢條件。 當然&#xff0c;各種通配符也可以組合使用。組合使用各種通配符時&#xff0c;一定要弄清其表示的匹配條…

QT分頁控件,開源,供大家使用

下載地址&#xff1a;http://files.cnblogs.com/dragonsuc/qt5.rar 轉載于:https://www.cnblogs.com/dragonsuc/p/4242342.html

使用ESCAPE定義轉義符

6.5.5 使用ESCAPE定義轉義符 在使用LIKE關鍵字進行模糊查詢時&#xff0c;“%”、“_”和“[]”單獨出現時&#xff0c;會被認為是通配符。為了在字符數據類型的列中查詢是否存在百分號&#xff08;%&#xff09;、下劃線&#xff08;_&#xff09;或者方括號&#xff08;[]&…