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

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

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

    Decode360's Blog

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

      BlogJava :: 首頁 :: 新隨筆 :: 聯系 ::  :: 管理 ::
      302 隨筆 :: 26 文章 :: 82 評論 :: 0 Trackbacks
    ??? 關系代數是關系數據庫系統查詢語言的理論基礎
    ?
    一、關系代數的9種操作:
    ?
    ??? 關系代數中包括了:并、交、差、乘、選擇、投影、聯接、除、自然聯接等操作。
    ?
    五個基本操作:
    ??? 并(∪)、差(-)、笛卡爾積(×)、投影(σ)、選擇(π)
    ?
    四個組合操作:
    ??? 交(∩)、聯接(等值聯接)、自然聯接(RCROSS.gifS)、除法(÷)
    注2:等值連接表示先做笛卡爾積(×)之后,對相應列進行選擇或等值關聯后的結果(僅篩選行、不篩選列)
    注2:自然連接表示兩個關系中若有相同名稱的屬性,則自動作為關聯條件,且僅列出一列
    ?
    ?
    二、關系代數表達式:
    ?
    ??? 由關系代數運算經有限次復合而成的式子稱為關系代數表達式。這種表達式的運算結果仍然是一個關系。可以用關系代數表達式表示對數據庫的查詢和更新操作。
    ?
    ?
    三、舉例說明:
    ?
    ??? 設教學數據庫中有3個關系:

    ??? 學生關系S(SNO,SNAME,AGE,SEX)
    ??? 學習關系SC(SNO,CNO,GRADE)
    ??? 課程關系C(CNO,CNAME,TEACHER)
    ?
    ?
    (1) 檢索學習課程號為C2的學生學號與成績
    ------------------------------------
    SELECT SNO,GRADE
    ? FROM SC
    ?WHERE CNO='C2'
    ------------------------------------
    π SNO,GRADE(σCNO='C2'(SC))
    ************************************
    ?
    ?
    (2) 檢索學習課程號為C2的學生學號與姓名
    ------------------------------------
    SELECT SC.SNO,S.SNAME
    ? FROM SC,S
    ?WHERE SC.SNO=S.SNO
    ?? AND SC.CNO='C2'
    ------------------------------------
    π SNO,SNAME(σCNO='C2'(SCROSS.gifSC))
    此查詢涉及S和SC,先進行自然連接,然后再執行選擇投影操作。
    ----
    π SNO,SNAME(S)CROSS.gifπSNO(σCNO='C2'(SC)))
    自然連接的右分量為"學了C2課的學生學號的集合"。
    此表達式比前一個表達式優化,執行起來要省時間、省空間。
    ************************************
    ?
    ?
    (3) 檢索選修課程名為MATHS的學生學號與姓名
    ------------------------------------
    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'(SCROSS.gifSCCROSS.gifC))
    ************************************
    ?
    ?
    (4) 檢索選修課程號為C2或C4的學生學號
    ------------------------------------
    SELECT SNO
    ? FROM SC
    ?WHERE CNO='C2'
    ??? OR CNO='C4'
    ------------------------------------
    π SNO(σ CNO='C2'∨CNO='C4'(SC))
    ************************************
    ?
    ?
    (5) 檢索至少選修課程號為C2或C4的學生學號
    ------------------------------------
    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) 檢索不學C2課的學生姓名與年齡
    ------------------------------------
    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'(SCROSS.gifSC))
    ************************************
    ?
    ?
    (7) 檢索學習全部課程的學生姓名
    ------------------------------------
    這個定義用SQL表示比較麻煩,略過
    ------------------------------------
    π SNO,CNO(SC)÷πCNO(C)
    先用除法取出選取所有課程的SNO集(除法可以理解為一個Filter)
    π SNAME(S?CROSS.gif (πSNO,CNO(SC)÷πCNO(C)))
    再關聯S表取出SNAME
    ************************************
    ?
    ?
    (8) 檢索所學課程包含S3所學課程的學生學號
    ------------------------------------
    這個定義用SQL表示比較麻煩,略過
    ------------------------------------
    π SNO,CNO(SC)÷?πCNO(σSNO='S3'(SC))
    同樣運用了除法的特性
    ************************************
    ?
    ?
    (9) 將新課程元組('C10','PHYSICS','YU')插入到關系C中
    ------------------------------------
    INSERT INTO C VALUES('C10','PHYSICS','YU')
    ------------------------------------
    (C('C10','PHYSICS','YU'))
    記住該符號的用法
    ************************************
    ?
    ?
    (10) 將學號S4選修課程號為C4的成績改為85分
    ------------------------------------
    UPDATE SC SET GRADE=85
    ?WHERE SNO='S4'
    ?? AND CNO='C4'
    ------------------------------------
    (SC('S4','C4',?)('S4','C4',85))
    先用''實現DELETE功能,再用'∪'實現INSERT功能
    注意使用?來表示檢索時忽略該字段值
    ************************************
    ?
    ?
    四、關系代數表達式的優化:
    ?
    ? ? 目的:為了系統在執行時既省時間又能提高效率。
    ? ? 基本策略:先做選擇,運用投影去除多余屬性等等。
    ? ? 優化算法:語法樹(盡量提前做選擇操作;在每個操作后,應做個投影操作,去掉不用的屬性值)
    ?
    ??? 例如:
    ?
    ??? π SNO,SNAME(σGRADE>60(SCROSS.gifSC)) 進行優化后轉換為:
    ??? π SNO,SNAME(πSNO,SNAME(S)CROSS.gifπSNO(σGRADE>60(SC)))
    ??? --即提前做選擇操作;在每個操作后,應做個投影操作,去掉不用的屬性值
    ?
    ?
    ??? 又如:
    ?
    ??? S(S#,SNAME,AGE,SEX)
    ??? SC(S#,C#,GRADE)
    ??? C(C#,CNAME,TEACHER)
    ?
    ??? π CNAME,TEACHER(σSEX='女'(SCROSS.gifSCCROSS.gifC)) 進行優化后轉換為:
    ??? πCNAME,TEACHER(CCROSS.gifπC#(πS#,C#(SC)CROSS.gifπS#(σSEX='女'(S))))
    ?
    ??? 優化前和優化后的語法樹如下所示:
    ?
    ??? tree.JPG
    ?




    -The End-

    posted on 2009-04-15 22:12 decode360-3 閱讀(2041) 評論(1)  編輯  收藏 所屬分類: Exam

    評論

    # re: 數據庫關系代數表達式學習 2016-04-18 00:09 oyld
    最后兩張圖順序是不是反了?  回復  更多評論
      

    主站蜘蛛池模板: 久久亚洲国产成人影院网站| 啦啦啦在线免费视频| 国产精品亚洲产品一区二区三区| 亚洲色大网站WWW永久网站| 成人无码区免费A片视频WWW| 亚洲图片校园春色| 免费在线观看的网站| 亚洲欧洲日韩极速播放| 国产真实伦在线视频免费观看| 国产亚洲精品仙踪林在线播放| 免费一级毛片在级播放| 九九久久国产精品免费热6| 亚洲一区二区三区在线观看精品中文 | 成人片黄网站色大片免费| 亚洲av片在线观看| 免费在线观看黄网| 国产拍拍拍无码视频免费| 亚洲精品福利在线观看| 在线免费观看一级毛片| 一级视频在线免费观看| 亚洲V无码一区二区三区四区观看| **真实毛片免费观看| 亚洲日韩一区精品射精| 国产精品亚洲w码日韩中文| 性xxxx视频免费播放直播| 亚洲成a人片在线观看精品| 免费人成在线观看网站品爱网日本 | 99久久免费观看| 亚洲国产人成在线观看| 国产美女无遮挡免费视频 | h视频在线免费观看| 亚洲精品日韩中文字幕久久久| 成人毛片免费观看视频在线| 一级大黄美女免费播放| 亚洲免费观看在线视频| 亚洲国产精品一区二区第一页免| 免费无码成人AV在线播放不卡| 亚洲国产成人久久精品软件| 国产精品亚洲аv无码播放| 免费无码又爽又刺激毛片| 国内精品免费久久影院|