自連接

9.3? 表的連接類型

9.3.1? 自連接

自連接是指表與其自身進行連接,這就需要用到前面介紹的表別名。下面通過一個具體實例來講解自連接的應用。

實例5? 自連接的使用方法

查詢成績中存在不及格課程的學生的姓名、所在系、所有的課程及成績信息。如果采用前面介紹的SELECT語句查詢方法,該實例的實現要分為兩步。

1.查詢存在不及格課程的學生的學號

之所以查詢學號,是因為學號是學生的惟一標識信息。代碼:

SELECT ??DISTINCT? SNO
FROM ??STUDENT
WHERE??MARK<60

運行結果如圖9.5所示。

?
圖9.5? 不及格課程學生的學號

注意?因為可能有的學生的不及格課程多于1門,因此在SELECT子句中使用了DISTINCT關鍵詞,去除重復的學號。

2.根據學號查詢相關信息

根據查詢的學號結果,查詢這些學號的學生的姓名、所在系、所有所修課程及成績信息。代碼:

SELECT ??SNAME, DNAME, CNO, MARK
FROM ??STUDENT
WHERE??SNO IN (‘9702’,’9703’,’9705’)
ORDER BY??SNAME

運行結果如圖9.6所示。

?
圖9.6? 根據學號查詢的相關信息

而如果采用表的自連接,只要通過一步查詢就可以實現該實例。代碼:

SELECT ??DISTINCT S1.SNAME, S1.DNAME, S1.CNO, S1.MARK
FROM ??STUDENT AS S1, STUDENT AS S2
WHERE??S1.SNO = S2.SNO
AND???S2. MARK<60
ORDER BY??S1.SNAME

運行結果如圖9.7所示。

代碼中,FROM子句中的兩個表實際上都是表STUDENT。為了獨立地使用它們,采用上節介紹的表別名方法,分別為其取別名S1和S2。這樣就可以在WHERE子句中,使用S2設定分數查詢條件,而在SELECT子句中,使用S1查詢滿足條件的結果。

需要說明一點,SELECT子句同樣要有關鍵字DISTINCT,如果沒有使用DISTINCT關鍵字,如下面的代碼:

?
圖9.7? 采用表的自連接執行的查詢結果

SELECT ??S1.SNAME, S1.DNAME, S1.CNO, S1.MARK
FROM ??STUDENT AS S1, STUDENT AS S2
WHERE??S1.SNO = S2.SNO
AND???S2. MARK<60
ORDER BY??S1.SNAME

運行結果如圖9.8所示。

?
圖9.8? 采用表的自連接但沒有去除重復記錄的查詢結果

可以發現,結果表中出現了重復的記錄。下面分析一下代碼的執行過程,從中就不難發現重復記錄產生的原因。

系統首先執行FROM子句,將STUDENT表S1與它自身S2的笛卡爾積,作為中間表。實際上,該中間表的每一條記錄包含兩部分信息,一部分是S1的記錄,一部分是S2的記錄。而后執行WHERE子句,在中間表中,搜索S2中成績低于60分的學生的記錄,同時要求記錄中S1與S2是同一個學生的記錄即學號相同。最后執行SELECT語句,從中間表獲取S1中相應的信息作為結果表。

當執行WHERE子句,從中間表中逐條搜索S2中成績低于60分的學生的記錄時,由于孫慶有兩門課程不及格,所以對于每門不及格的記錄都滿足搜索條件,因此導致了從S1得到的信息中出現了重復記錄。

簡單來說,中間表是沒有重復記錄的,但是S1部分字段是有重復的,而結果集提取的只是S1部分的字段,因此就有可能有重復記錄。

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

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

相關文章

從此記錄

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

LIKE運算符

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

AND運算符

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

Cron表達式【一】

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

OR運算符

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

Java基礎---網絡編程

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

AND、OR運算符的組合使用

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

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

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

IN運算符的使用

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

app后端設計(php)

來源&#xff1a;http://blog.csdn.net/column/details/mobilebackend.html?page1 做了3年app相關的系統架構&#xff0c;api設計&#xff0c;先后在3個創業公司中工作&#xff0c;經歷過手機網頁端&#xff0c;android客戶端&#xff0c;iphone客戶端&#xff0c;現在從事日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;[]&…

STL學習小結

STL就是Standard Template Library&#xff0c;標準模板庫。這可能是一個歷史上最令人興奮的工具的最無聊的術語。從根本上說&#xff0c;STL是一些“容器”的集合&#xff0c;這些“容器”有list, vector,set,map等&#xff0c;STL也是算法和其它一些組件的集合。這里的“容器…

內連接(INNER JOIN)

9.3.3 內連接&#xff08;INNER JOIN&#xff09; 內連接也稱為等同連接&#xff0c;返回的結果集是兩個表中所有相匹配的數據&#xff0c;而舍棄不匹配的數據。也就是說&#xff0c;在這種查詢中&#xff0c;DBMS只返回來自源表中的相關的行&#xff0c;即查詢的結果表包含的…