演示文稿數(shù)據(jù)庫原理嵌套查詢_第1頁
演示文稿數(shù)據(jù)庫原理嵌套查詢_第2頁
演示文稿數(shù)據(jù)庫原理嵌套查詢_第3頁
演示文稿數(shù)據(jù)庫原理嵌套查詢_第4頁
演示文稿數(shù)據(jù)庫原理嵌套查詢_第5頁
已閱讀5頁,還剩27頁未讀 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡介

(優(yōu)選)數(shù)據(jù)庫原理嵌套查詢現(xiàn)在是1頁\一共有32頁\編輯于星期五第三章關(guān)系數(shù)據(jù)庫標(biāo)準(zhǔn)語言SQL3.1SQL概述3.2數(shù)據(jù)定義3.3查詢3.4數(shù)據(jù)更新3.5視圖現(xiàn)在是2頁\一共有32頁\編輯于星期五3.3查詢3.3.1概述3.3.2單表查詢3.3.3連接查詢3.3.4嵌套查詢3.3.5集合查詢3.3.6小結(jié)3.3.4嵌套查詢現(xiàn)在是3頁\一共有32頁\編輯于星期五3.3.4嵌套查詢嵌套查詢概述嵌套查詢分類嵌套查詢求解方法引出子查詢的謂詞

現(xiàn)在是4頁\一共有32頁\編輯于星期五3.3.4嵌套查詢【例1】查詢選修了2號(hào)課程的學(xué)生的姓名SELECTSname FROMStudent,SCWHERE方法1:復(fù)合條件查詢Student.Sno=SC.SnoandCno='2'現(xiàn)在是5頁\一共有32頁\編輯于星期五3.3.4嵌套查詢【例1】查詢選修了2號(hào)課程的學(xué)生的姓名方法2:換個(gè)角度想問題思路:從Student表中查詢學(xué)生的姓名,這個(gè)學(xué)生應(yīng)該是選修了2號(hào)課程的學(xué)生。思路:從Student表中查詢學(xué)生的姓名,這個(gè)學(xué)生應(yīng)該在選修了2號(hào)課程的學(xué)生集合里。現(xiàn)在是6頁\一共有32頁\編輯于星期五3.3.4嵌套查詢【例1】查詢選修了2號(hào)課程的學(xué)生的姓名方法2:換個(gè)角度想問題(SELECTSnoFROMSCWHERECno='2');外層查詢/父查詢內(nèi)層查詢/子查詢SELECTSname FROMStudentWHERESnoIN現(xiàn)在是7頁\一共有32頁\編輯于星期五3.3.4嵌套查詢一、嵌套查詢概述一個(gè)SELECT-FROM-WHERE語句稱為一個(gè)查詢塊將一個(gè)查詢塊嵌套在另一個(gè)查詢塊的WHERE子句或HAVING短語的條件中的查詢稱為嵌套查詢現(xiàn)在是8頁\一共有32頁\編輯于星期五3.3.4嵌套查詢子查詢的限制不能使用ORDERBY子句層層嵌套方式反映了SQL語言的結(jié)構(gòu)化有些嵌套查詢可以用連接運(yùn)算替代現(xiàn)在是9頁\一共有32頁\編輯于星期五不相關(guān)子查詢子查詢的查詢條件不依賴于父查詢相關(guān)子查詢子查詢的查詢條件依賴于父查詢二、嵌套查詢分類3.3.4嵌套查詢現(xiàn)在是10頁\一共有32頁\編輯于星期五三、嵌套查詢求解方法不相關(guān)子查詢是由里向外逐層處理。即每個(gè)子查詢?cè)谏弦患?jí)查詢處理之前求解,子查詢的結(jié)果用于建立其父查詢的查找條件。3.3.4嵌套查詢現(xiàn)在是11頁\一共有32頁\編輯于星期五相關(guān)子查詢首先取外層查詢中表的第一個(gè)元組,根據(jù)它與內(nèi)層查詢相關(guān)的屬性值處理內(nèi)層查詢,若WHERE子句返回值為真,則取此元組放入結(jié)果表;然后再取外層表的下一個(gè)元組;重復(fù)這一過程,直至外層表全部檢查完為止。3.3.4嵌套查詢?nèi)⑶短撞樵兦蠼夥椒ǎɡm(xù))現(xiàn)在是12頁\一共有32頁\編輯于星期五四、引出子查詢的謂詞帶有IN謂詞的子查詢帶有比較運(yùn)算符的子查詢帶有ANY或ALL謂詞的子查詢帶有EXISTS謂詞的子查詢3.3.4嵌套查詢現(xiàn)在是13頁\一共有32頁\編輯于星期五(1)帶有IN謂詞的子查詢(續(xù))【例2】查詢選修了課程名為“信息系統(tǒng)”的學(xué)生學(xué)號(hào)和姓名①首先在Course關(guān)系中找出“信

息系統(tǒng)”的課程號(hào),結(jié)果為3號(hào)②然后在SC關(guān)系中找出選修了3號(hào)課程的學(xué)生學(xué)號(hào)③最后在Student關(guān)系中取出Sno和Sname(SELECTCno

FROMCourseWHERECname=‘信息系統(tǒng)’));(SELECTSno

FROMSCWHERECnoINSELECTSno,Sname

FROMStudentWHERESnoININ可由‘=’代替現(xiàn)在是14頁\一共有32頁\編輯于星期五(2)帶有比較運(yùn)算符的子查詢

當(dāng)能確切知道內(nèi)層查詢返回單值時(shí),可用比較運(yùn)算符(>,<,=,>=,<=,!=或<>)。與ANY或ALL謂詞配合使用某一個(gè)全部現(xiàn)在是15頁\一共有32頁\編輯于星期五(3)ANY或ALL謂詞的子查詢【例3】查詢其他系中比信息系任意一個(gè)(某一個(gè))學(xué)生年齡小的學(xué)生姓名和年齡

SELECTSname,SageFROMStudentWHERESage<

ANY(SELECTSageFROMStudentWHERESdept='IS')

ANDSdept<>'IS';/*注意這是父查詢塊中的條件*/現(xiàn)在是16頁\一共有32頁\編輯于星期五(3)ANY或ALL謂詞的子查詢ANY和ALL謂詞有時(shí)可以用集函數(shù)實(shí)現(xiàn)ANY與ALL與集函數(shù)的對(duì)應(yīng)關(guān)系

=

<>或!=

<<=>>=ANY

IN

--

<MAX<=MAX>MIN>=MINALL--

NOTIN

<MIN<=MIN>MAX>=MAX

用集函數(shù)實(shí)現(xiàn)子查詢通常比直接用ANY或ALL查詢效率要高,因?yàn)榍罢咄ǔD軌驕p少比較次數(shù)現(xiàn)在是17頁\一共有32頁\編輯于星期五IN

(SELECTSnoFROMSCWHERECno='2');①SELECTSname FROMStudentWHERESno②SELECTSnameFROMStudentWHEREEXISTS(SELECT*FROMSC/*相關(guān)子查詢*/WHERESno=Student.SnoANDCno='2');1、什么是嵌套查詢2、嵌套查詢分類不相關(guān)子查詢相關(guān)子查詢3、嵌套查詢執(zhí)行方法3.4.3嵌套查詢①②4、引出子查詢的謂詞

現(xiàn)在是18頁\一共有32頁\編輯于星期五(4)帶有EXISTS謂詞的子查詢1.EXISTS謂詞2.NOTEXISTS謂詞3.不同形式的查詢間的替換4.☆用EXISTS/NOTEXISTS實(shí)現(xiàn)全稱量詞5.☆用EXISTS/NOTEXISTS實(shí)現(xiàn)邏輯蘊(yùn)函現(xiàn)在是19頁\一共有32頁\編輯于星期五(4)帶有EXISTS謂詞的子查詢1.EXISTS謂詞存在量詞

帶有EXISTS謂詞的子查詢不返回任何數(shù)據(jù),只產(chǎn)生邏輯真值“true”或邏輯假值“false”。若內(nèi)層查詢結(jié)果非空,則返回真值若內(nèi)層查詢結(jié)果為空,則返回假值由EXISTS引出的子查詢,其目標(biāo)列表達(dá)式通常都用*,因?yàn)閹XISTS的子查詢只返回真值或假值,給出列名無實(shí)際意義2.NOTEXISTS謂詞現(xiàn)在是20頁\一共有32頁\編輯于星期五(4)帶有EXISTS謂詞的子查詢【例1】查詢所有選修了2號(hào)課程的學(xué)生姓名SELECTSnameFROMStudentWHEREEXISTS

(SELECT*FROMSCWHERE思路分析:查詢Student中這樣的學(xué)生姓名,只要在SC表中存在該學(xué)生選修1號(hào)課程的記錄。Sno=Student.SnoAND Cno='1');現(xiàn)在是21頁\一共有32頁\編輯于星期五(4)帶有EXISTS謂詞的子查詢【例1】查詢所有選修了2號(hào)課程的學(xué)生姓名SELECTSnameFROMStudent,SCWHEREStudent.Sno=SC.Sno

AND

SC.Cno='1';等值連接實(shí)現(xiàn):現(xiàn)在是22頁\一共有32頁\編輯于星期五(4)帶有EXISTS謂詞的子查詢SELECTSnameFROMStudentWHERE(SELECT*FROMSCWHERESno=Student.Sno ANDCno='1');連接運(yùn)算的實(shí)現(xiàn)?NOTEXISTS【例4】查詢沒有選修2號(hào)課程的學(xué)生姓名思路分析:查詢Student中這樣的學(xué)生姓名,只要在SC表中不存在該學(xué)生選修1號(hào)課程的記錄?,F(xiàn)在是23頁\一共有32頁\編輯于星期五(4)帶有EXISTS謂詞的子查詢SELECTSnameFROMStudent,SCWHEREStudent.Sno=SC.SnoANDSC.Cno<>'1';【例4】查詢沒有選修2號(hào)課程的學(xué)生姓名現(xiàn)在是24頁\一共有32頁\編輯于星期五Student表CSCSMAIS20191819男女女男李勇劉晨王敏張立200215121200215122200215123200515125SdeptSageSsexSnameSnoSC表928588908012323200215121200215121200215121200215122200215122GradeCnoSnoSELECTSnameFROMStudentWHERENOTEXISTS(SELECT*FROMSCWHERESno=Student.Sno ANDCno='1');√結(jié)果表Sname劉晨王敏張立現(xiàn)在是25頁\一共有32頁\編輯于星期五Student表SC表928588908012323200215121200215121200215121200215122200215122GradeCnoSnoSELECTSnameFROMStudent,SCWHEREStudent.Sno=SC.SnoANDSC.Cno<>'1';CSCSMAIS20191819男女女男李勇劉晨王敏張立200215121200215122200215123200515125SdeptSageSsexSnameSno結(jié)果表Sname李勇×

√×

注意:約束的是單個(gè)元組現(xiàn)在是26頁\一共有32頁\編輯于星期五(4)帶有EXISTS謂詞的子查詢3.不同形式的查詢間的替換所有帶IN謂詞、比較運(yùn)算符、ANY和ALL謂詞的子查詢都能用帶EXISTS謂詞的子查詢等價(jià)替換。一些帶EXISTS或NOTEXISTS謂詞的子查詢不能被其他形式的子查詢等價(jià)替換現(xiàn)在是27頁\一共有32頁\編輯于星期五(4)帶有EXISTS謂詞的子查詢4.用EXISTS()/NOTEXISTS實(shí)現(xiàn)全稱量詞()謂詞:P(x1,x2,…,xn)被稱為n元謂詞。其中P是謂詞,代表一個(gè)確定的特征或關(guān)系(名)。x1,x2,…,xn稱為謂詞的參量,一般表示個(gè)體。Like(I,Music)例如:“我喜歡音樂”現(xiàn)在是28頁\一共有32頁\編輯于星期五(4)帶有EXISTS謂詞的子查詢4.用EXISTS()/NOTEXISTS實(shí)現(xiàn)全稱量詞()如果謂詞公式P(x)對(duì)于所有可能變量x都具有True值,則用(?x)P(x)表示。對(duì)于謂詞公式P(x),至少有一個(gè)變?cè)猉可使P(x)為True值,則用(?x)P(x)表示?,F(xiàn)在是29頁\一共有32頁\編輯于星期五(4)帶有EXISTS謂詞的子查詢(x)P≡(x(P))(x)P:例如:P表示謂詞“學(xué)生x選修了課程A”不存在這樣的學(xué)生x,x沒有選修課程A(x(P))全部學(xué)生都選修了課程A現(xiàn)在是30頁\一共有32頁\編輯于星期五(4)帶有EXISTS謂詞的子查詢【例5】檢索全部學(xué)生都選修的課程號(hào)與課程名

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

最新文檔

評(píng)論

0/150

提交評(píng)論