<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    Decode360's Blog

    業(yè)精于勤而荒于嬉 QQ:150355677 MSN:decode360@hotmail.com

      BlogJava :: 首頁(yè) :: 新隨筆 :: 聯(lián)系 ::  :: 管理 ::
      397 隨筆 :: 33 文章 :: 29 評(píng)論 :: 0 Trackbacks
    數(shù)據(jù)庫(kù)關(guān)系代數(shù)表達(dá)式學(xué)習(xí)
    ?
    ??? 關(guān)系代數(shù)是關(guān)系數(shù)據(jù)庫(kù)系統(tǒng)查詢語(yǔ)言的理論基礎(chǔ)。很有必要學(xué)習(xí)一下,有些是用代數(shù)表達(dá)式很方便的東西,用SQL寫(xiě)出來(lái)還是挺麻煩的,并不是想象當(dāng)中那么直接。
    ?
    一、關(guān)系代數(shù)的9種操作:
    ?
    ??? 關(guān)系代數(shù)中包括了:并、交、差、乘、選擇、投影、聯(lián)接、除、自然聯(lián)接等操作。
    ?
    五個(gè)基本操作:
    ??? 并(∪)、差(-)、笛卡爾積(×)、投影(σ)、選擇(π)
    ?
    四個(gè)組合操作:
    ??? 交(∩)、聯(lián)接(等值聯(lián)接)、自然聯(lián)接(RcrossS)、除法(÷)
    注2:等值連接表示先做笛卡爾積(×)之后,對(duì)相應(yīng)列進(jìn)行選擇或等值關(guān)聯(lián)后的結(jié)果(僅篩選行、不篩選列)
    注2:自然連接表示兩個(gè)關(guān)系中若有相同名稱的屬性,則自動(dòng)作為關(guān)聯(lián)條件,且僅列出一列
    ?
    ?
    二、關(guān)系代數(shù)表達(dá)式:
    ?
    ??? 由關(guān)系代數(shù)運(yùn)算經(jīng)有限次復(fù)合而成的式子稱為關(guān)系代數(shù)表達(dá)式。這種表達(dá)式的運(yùn)算結(jié)果仍然是一個(gè)關(guān)系。可以用關(guān)系代數(shù)表達(dá)式表示對(duì)數(shù)據(jù)庫(kù)的查詢和更新操作。
    ?
    ?
    三、舉例說(shuō)明:
    ?
    ??? 設(shè)教學(xué)數(shù)據(jù)庫(kù)中有3個(gè)關(guān)系:

    ??? 學(xué)生關(guān)系S(SNO,SNAME,AGE,SEX)
    ??? 學(xué)習(xí)關(guān)系SC(SNO,CNO,GRADE)
    ??? 課程關(guān)系C(CNO,CNAME,TEACHER)
    ?
    ?
    (1) 檢索學(xué)習(xí)課程號(hào)為C2的學(xué)生學(xué)號(hào)與成績(jī)
    ------------------------------------
    SELECT SNO,GRADE
    ? FROM SC
    WHERE CNO='C2'
    ------------------------------------
    π SNO,GRADE(σCNO='C2'(SC))
    ************************************
    ?
    ?
    (2) 檢索學(xué)習(xí)課程號(hào)為C2的學(xué)生學(xué)號(hào)與姓名
    ------------------------------------
    SELECT SC.SNO,S.SNAME
    ? FROM SC,S
    WHERE SC.SNO=S.SNO
    ?? AND SC.CNO='C2'
    ------------------------------------
    π SNO,SNAME(σCNO='C2'(ScrossSC))
    此查詢涉及S和SC,先進(jìn)行自然連接,然后再執(zhí)行選擇投影操作。
    ----
    π SNO,SNAME(S)crossπSNO(σCNO='C2'(SC)))
    自然連接的右分量為"學(xué)了C2課的學(xué)生學(xué)號(hào)的集合"。
    此表達(dá)式比前一個(gè)表達(dá)式優(yōu)化,執(zhí)行起來(lái)要省時(shí)間、省空間。
    ************************************
    ?
    ?
    (3) 檢索選修課程名為MATHS的學(xué)生學(xué)號(hào)與姓名
    ------------------------------------
    SELECT SC.SNO,S.SNAME
    ? FROM SC,S,C
    WHERE SC.SNO=S.SNO
    ?? AND SC.CNO=C.CNO
    ?? AND C.CNAME='MATHS'
    ------------------------------------
    π SNO,SANME(σCNAME='MATHS'(ScrossSCcrossC))
    ************************************
    ?
    ?
    (4) 檢索選修課程號(hào)為C2或C4的學(xué)生學(xué)號(hào)
    ------------------------------------
    SELECT SNO
    ? FROM SC
    WHERE CNO='C2'
    ??? OR CNO='C4'
    ------------------------------------
    π SNO(σ CNO='C2'∨CNO='C4'(SC))
    ************************************
    ?
    ?
    (5) 檢索至少選修課程號(hào)為C2或C4的學(xué)生學(xué)號(hào)
    ------------------------------------
    SELECT SA.SNO
    ? FROM SC AS SA,SC AS SB
    WHERE SA.SNO=SB.SNO
    ?? AND SA.CNO='C2'
    ?? AND SB.CNO='C4'
    ------------------------------------
    π 1(σ1=4∧2='C2'∧5='C4'(SC×SC))
    ************************************
    ?
    ?
    (6) 檢索不學(xué)C2課的學(xué)生姓名與年齡
    ------------------------------------
    SELECT SNAME,AGE
    ? FROM S
    MINUS
    SELECT S.SNAME,S.AGE
    ? FROM SC,S
    WHERE SC.SNO=S.SNO
    ?? AND SC.CNO='C2'
    (Oracle)
    ------------------------------------
    π SNAME,AGE(S)-πSNAME,AGE(σCNO='C2'(ScrossSC))
    ************************************
    ?
    ?
    (7) 檢索學(xué)習(xí)全部課程的學(xué)生姓名
    ------------------------------------
    這個(gè)定義用SQL表示比較麻煩,略過(guò)
    ------------------------------------
    π SNO,CNO(SC)÷πCNO(C)
    先用除法取出選取所有課程的SNO集(除法可以理解為一個(gè)Filter)
    π SNAME(S cross (πSNO,CNO(SC)÷πCNO(C)))
    再關(guān)聯(lián)S表取出SNAME
    ************************************
    ?
    ?
    (8) 檢索所學(xué)課程包含S3所學(xué)課程的學(xué)生學(xué)號(hào)
    ------------------------------------
    這個(gè)定義用SQL表示比較麻煩,略過(guò)
    ------------------------------------
    π SNO,CNO(SC)÷ πCNO(σSNO='S3'(SC))
    同樣運(yùn)用了除法的特性
    ************************************
    ?
    ?
    (9) 將新課程元組('C10','PHYSICS','YU')插入到關(guān)系C中
    ------------------------------------
    INSERT INTO C VALUES('C10','PHYSICS','YU')
    ------------------------------------
    (C('C10','PHYSICS','YU'))
    記住該符號(hào)的用法
    ************************************
    ?
    ?
    (10) 將學(xué)號(hào)S4選修課程號(hào)為C4的成績(jī)改為85分
    ------------------------------------
    UPDATE SC SET GRADE=85
    WHERE SNO='S4'
    ?? AND CNO='C4'
    ------------------------------------
    (SC('S4','C4',?)('S4','C4',85))
    先用''實(shí)現(xiàn)DELETE功能,再用'∪'實(shí)現(xiàn)INSERT功能
    注意使用?來(lái)表示檢索時(shí)忽略該字段值
    ************************************
    ?
    ?
    四、關(guān)系代數(shù)表達(dá)式的優(yōu)化:
    ?
    ? ? 目的:為了系統(tǒng)在執(zhí)行時(shí)既省時(shí)間又能提高效率。
    ? ? 基本策略:先做選擇,運(yùn)用投影去除多余屬性等等。
    ? ? 優(yōu)化算法:語(yǔ)法樹(shù)(盡量提前做選擇操作;在每個(gè)操作后,應(yīng)做個(gè)投影操作,去掉不用的屬性值)
    ?
    ??? 例如:
    ?
    ??? π SNO,SNAME(σGRADE>60(ScrossSC)) 進(jìn)行優(yōu)化后轉(zhuǎn)換為:
    ??? π SNO,SNAME(πSNO,SNAME(S)crossπSNO(σGRADE>60(SC)))
    ??? --即提前做選擇操作;在每個(gè)操作后,應(yīng)做個(gè)投影操作,去掉不用的屬性值
    ?
    ?
    ??? 又如:
    ?
    ??? S(S#,SNAME,AGE,SEX)
    ??? SC(S#,C#,GRADE)
    ??? C(C#,CNAME,TEACHER)
    ?
    ??? π CNAME,TEACHER(σSEX='女'(ScrossSCcrossC)) 進(jìn)行優(yōu)化后轉(zhuǎn)換為:
    ??? πCNAME,TEACHER(CcrossπC#(πS#,C#(SC)crossπS#(σSEX='女'(S))))
    ?
    ??? 優(yōu)化前和優(yōu)化后的語(yǔ)法樹(shù)如下所示:
    ?
    ??? syntax_tree
    ?
    ?
    posted on 2009-04-15 22:12 decode360 閱讀(18679) 評(píng)論(4)  編輯  收藏 所屬分類: 12.Certified

    評(píng)論

    # re: 數(shù)據(jù)庫(kù)關(guān)系代數(shù)表達(dá)式學(xué)習(xí) 2014-06-06 09:17 dsfd
    好文章。beikemusic.com  回復(fù)  更多評(píng)論
      

    # re: 數(shù)據(jù)庫(kù)關(guān)系代數(shù)表達(dá)式學(xué)習(xí) 2015-03-25 20:12 chacouse
    博主你的文章很好~~不過(guò)(5) 檢索至少選修課程號(hào)為C2或C4的學(xué)生學(xué)號(hào) 這個(gè)地方應(yīng)該存在筆誤 根據(jù)你的代數(shù)式子,題目應(yīng)該是C2和C4 即檢索同時(shí)選修C2 C4課程的學(xué)生學(xué)號(hào)。 如果冒犯請(qǐng)?jiān)徫襼學(xué)渣一枚  回復(fù)  更多評(píng)論
      

    # re: 數(shù)據(jù)庫(kù)關(guān)系代數(shù)表達(dá)式學(xué)習(xí) 2015-08-26 14:07 wzrong
    投影與選擇的符號(hào)寫(xiě)反了 不知道是否整體都有影響?  回復(fù)  更多評(píng)論
      

    # re: 數(shù)據(jù)庫(kù)關(guān)系代數(shù)表達(dá)式學(xué)習(xí)[未登錄](méi) 2016-01-17 14:54 jason
    非常棒 寫(xiě)的很好 如果能把語(yǔ)法樹(shù)相關(guān)的再詳細(xì)點(diǎn)就好了  回復(fù)  更多評(píng)論
      

    主站蜘蛛池模板: 毛片大全免费观看| 成人永久免费福利视频网站| 久久精品国产亚洲av麻豆蜜芽 | 亚洲一区电影在线观看| 国产色婷婷精品免费视频| 99久久免费国产精精品| 亚洲人成网国产最新在线| 精品国产亚洲一区二区在线观看 | 亚洲人成国产精品无码| 24小时在线免费视频| 激情婷婷成人亚洲综合| 亚洲av无码潮喷在线观看| 啦啦啦手机完整免费高清观看| 国产成人高清精品免费观看| 亚洲免费在线观看视频| 中文字幕亚洲图片| 女人被免费视频网站| 成人A片产无码免费视频在线观看| 日韩亚洲产在线观看| 久久精品7亚洲午夜a| 国产精品99久久免费| 18pao国产成视频永久免费| 一级毛片高清免费播放| 中文字幕 亚洲 有码 在线| 亚洲国产精品一区二区第一页| 国产成人免费一区二区三区| 67pao强力打造高清免费| 久久久久久毛片免费看| 亚洲av永久无码天堂网| 亚洲免费观看网站| 久久久亚洲欧洲日产国码农村| 亚洲精品综合久久| 国产黄色片在线免费观看| 免费A级毛片无码A∨免费| a级毛片毛片免费观看久潮 | 麻豆一区二区免费播放网站 | 18禁美女黄网站色大片免费观看| 国产99久久久久久免费看| 黄色网址免费在线| 久久精品国产亚洲av品善| 亚洲一卡二卡三卡四卡无卡麻豆|