數據庫系統(tǒng)大題.doc_第1頁
數據庫系統(tǒng)大題.doc_第2頁
數據庫系統(tǒng)大題.doc_第3頁
數據庫系統(tǒng)大題.doc_第4頁
數據庫系統(tǒng)大題.doc_第5頁
已閱讀5頁,還剩6頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領

文檔簡介

1、一個學生可選修多門課,一門課有若干學生選修; 一個教師可講授多門課,一門課只有一個教師講授; 一個學生選修一門課,僅有一個成績。 要求:根據上述語義畫出 ER 圖,要求在圖中畫出實體的屬性并注明聯(lián)系的類型; 解答: 成績 教師編號 教師姓名 學生選修 m 課程 教師 講授 n n 1 學號 姓名 課程號課程名 1、設有如下所示的關系 S(S#,SNAME,AGE,SEX)、C(C#,CNAME,TEACHER)和 SC(S#,C#,GRADE),試用關系代數表達式表 示下列查詢語句: (1)檢索“程軍”老師所授課程的課程號(C#)和課程名(CNAME)。 (2)檢索年齡大于 21 的男學生學號

2、(S#)和姓名(SNAME)。 (3)檢索至少選修“程軍”老師所授全部課程的學生姓名(SNAME)。 (4)檢索”李強”同學不學課程的課程號(C#)。 (5)檢索至少選修兩門課程的學生學號(S#)。 (6)檢索全部學生都選修的課程的課程號(C#)和課程名(CNAME)。 (7)檢索選修課程包含“程軍”老師所授課程之一的學生學號(S#)。 (8)檢索選修課程號為 k1 和 k5 的學生學號(S#)。 (9)檢索選修全部課程的學生姓名(SNAME)。 (10)檢索選修課程包含學號為 2 的學生所修課程的學生學號(S#)。 (11)檢索選修課程名為“C 語言”的學生學號(S#)和姓名(SNAME)。

3、 解:本題各個查詢語句對應的關系代數表達式表示如下: (1). C#,CNAME(TEACHER=程軍(C) (2). S#,SNAME(AGE21SEX=”男”(C) (3). SNAMEs S#,C#(sc)C#(TEACHER=程軍(C) (4). C#(C)- C#(SNAME=李強(S) SC) (5). S#(1=425 (SC SC) (6). C#,CNAME(C (S#,C#(sc)S#(S) (7). S#(SCC#(TEACHER=程軍(C) (8). S#,C#(sc)C#(C#=k1 C#=k5(C) (9). SNAMEs S#,C#(sc)C#(C) (10).

4、S#,C#(sc)C#(S#=2(SC) (11). S#,SNAMEs S#(SCCNAME=C 語言(C) 2、關系 R 和 S 如下圖所示,試計算 RS。 R ABCD abcd abef abhk bdef bddl ckcd ckef 1、設有如下關系表 R: R(No,NAME,SEX,AGE,CLASS) 主關鍵字是 NO 其中 NO 為學號,NAME 為姓名,SEX 為性別,AGE 為年齡,CLASS 為班號。 寫出實現下列功能的 SQL 語句。 插入一個記錄(25, “李明” , “男” ,21, “95031”); 插入“95031”班學號為 30、姓名為“鄭和”的學生記錄

5、; 將學號為 10 的學生姓名改為“王華” ; 將所有“95101”班號改為“95091” ; 刪除學號為 20 的學生記錄; 刪除姓“王”的學生記錄; 答案: INSERT INTO R VALUES(25, “李明” , “男” ,21, “95031”) INSERT INTO R(NO,NAME,CLASS) VALUES(30, “鄭和” , “95031”) UPDATE R SET NAME=“王華”WHERE NO10 UPDATE R SET CLASS“95091”WHERE CLASS“95101” DELETE FROM R WHERE NO=20 DELETE FRO

6、MR WHERE NAME LIKE“王” 2、設學生課程數據庫中有三個關系: 學生關系 S(S#,SNAME,AGE,SEX) 學習關系 SC(S#,C#,GRADE) 課程關系 C(C#,CNAME) 其中 S#、C#、SNAME、AGE、SEX、GRADE、CNAME 分別表示學號、課程號、姓名、年齡、性別、成績和課 程名。 S CD cd ef 用 SQL 語句表達下列操作 (1)檢索選修課程名稱為“MATHS”的學生的學號與姓名 (2)檢索至少學習了課程號為“C1”和“C2”的學生的學號 (3)檢索年齡在 18 到 20 之間(含 18 和 20)的女生的學號、姓名和年齡 (4)將一

7、個新學生元組(學號:200215128;姓名:王麗;年齡:19;性別:女)插入到 S 表中 (5)將選修課程號為“C1”的同學成績加 5 分 (6)找出每個學生超過他選修課程平均成績的課程號 (7)查詢查詢選修“C2”號課程且成績在 90 分以上的所有學生。 (8)查詢所有姓劉的學生的姓名、學號和性別 (9)檢索平均成績超過 80 分的學生學號和平均成績 (10)檢索選修了全部課程的學生姓名 (11)檢索選修了三門課以上的學生的姓名 (12)創(chuàng)建視圖 stu_info,包括選修“C1”號課程所有學生的學號、姓名、性別、年齡、選修課程號、課程名、成績 答案: (1)SELECT SNAME,AG

8、E FROM S,SC,C WHERE S.S#=SC.S# AND C.C#=SC.C# AND CNAME= MATHS (2) SELECT S# FROM SC WHERE CNO=C1 AND S# IN( SELECT S# FROM SC WHERE CNO=C2) (3)SELECT S#,SNAME,AGE FROM S WHERE AGE BETWEEN 18 AND 20 (4) INSERT INTO S(S#,SNAME,AGE,SEX) VALUES(“200215128”,”王麗”,19,”女”); (5) UPDATE SC SET GRADE = GRADE+

9、5 WHERE C#=C1; (6) SELECT S#,C# FROM S X WHERE GRADE=(SELECT AVG(GRADE) FROM C Y WHERE Y.S#=X.S#); (7) SELECT S.S#,SNAME FROM S,SC WHERE S.S#=SC.S# AND SC.C#=C2 AND SC.GRADE90; (8) SELECT SNAME,S#,SEX FROM S WHERE LIKE 劉%; (9) SELECT S# ,AVG(GRADE) 平均成績 FROM SC GROUP BY S# HAVING AVG(GRADE)80 (10) S

10、ELECT SNAME FROM S WHERE NOT EXISTS (SELECT * FROM C WHERE NOT EXISTS (SELECT * FROM SC WHERE S#=S.S# AND C#=C.C# ) ) (11) SELECT SNAME FROM S,SC WHERE S.S#=SC.S# GROUP BY SNAME HAVING COUNT(*)3 (12)CREATE VIEW STU_INFO AS SELECT S.SNO,SNAME,SEX,AGE,C.CNO,CNAME,GRADE FROM S,SC,C WHERE S.SNO=SC.SNO A

11、ND C.CNO= SC.CNO AND C.CNO=C1 3、設學生-課程數據庫中包括三個表: 學生表:Student (Sno,Sname,Sex,Sage,Sdept) 課程表:Course(Cno,Cname,Ccredit) 學生選課表:SC(Sno,Cno,Grade) 其中 Sno、Sname、Sex、Sage、Sdept、 Cno、Cname、Ccredit 、Grade 分別表示學號、姓名、性別、年齡、 所在系名、課程號、課程名、學分和成績。 試用 SQL 語言完成下列項操作: (1)查詢選修課程包括“1042”號學生所學的課程的學生學號 (2)創(chuàng)建一個計科系學生信息視圖 S

12、_CS_VIEW,包括 Sno 學號、Sname 姓名、Sex 性別; (3)通過上面第 2 題創(chuàng)建的視圖修改數據,把王平的名字改為王慧平 (4)創(chuàng)建一選修數據庫課程信息的視圖,視圖名稱為 datascore_view,包含學號、姓名、成績。 答案: (1) SELECT DISTINCT SNO FROM SC SCX WHERE NOT EXISTS (SELECT * FROM SC SCY WHERE SCY.SNO = 1042 AND NOT EXISTS (SELECT * FROM SC SCZ WHERE SCZ.SNO=SCX.SNO AND SCZ.CNO=SCY.CNO

13、); (2) CREATE VIEW S_CS_VIEW AS SELECT SNO,SNAME,SEX FROM STUDENT WHERE SDEPT=CS (3)UPDATE S_CS_VIEW SET SNAME= 王慧平 WHERE SNAME= 王平 (4) CREATE VIEW DATASCORE_VIEW AS SELECT SNO 學號、SNAME 姓名、GRADE 成績 FROM STUDENT,SC,COURSE WHERE STUDENT.SNO=SC.SNO AND COURSE.CNO=SC.CNO AND CNAME= 數據庫 1、設有關系模式 S-L-C(Sn

14、o,Sdept,Sloc,Cno,Grade),其中屬性分別表示:學號、所在系、學生住處、課程號、 成績。假定每個系的學生住在同一個地方,每個學生可選修多門課程,每門課程可被多個學生選修,請根據語義寫出 該關系模式的主碼及基本函數依賴,并通過模式分解,使其分解為與之等價的 3NF 模式集。 答:主碼為(Sno,Cno)。 基本函數依賴:(Sno,Cno) Grade Sno Sdept,(Sno,Cno) Sdept Sno Sloc,(Sno,Cno) Sloc,Sdept Sloc 分解結果(3NF):SC(Sno,Cn,Grade) S-D(Sno,Sdept) D-L(Sdept,Sl

15、oc) 2、已知學生關系模式 S(Sno,Sname,SD,Sdname,Course,Grade) 其中:Sno 學號、Sname 姓名、SD 系名、Sdname 系主任名、Course 課程、Grade 成績。 (1)寫出關系模式 S 的基本函數依賴和主碼。 (2)原關系模式 S 為幾范式?為什么?分解成高一級范式,并說明為什么? (3)將關系模式分解成 3NF,并說明為什么? (1)寫出關系模式 S 的基本函數依賴和主碼。 答: 關系模式 S 的基本函數依賴如下: SnoSname,SDSdname,SnoSD,(Sno,Course) Grade 關系模式 S 的碼為:(Sno,Cou

16、rse) 。 (2)原關系模式 S 為幾范式?為什么?分解成高一級范式,并說明為什么? 答: 原關系模式 S 是屬于 1NF 的,碼為(Sno,Course),非主屬性中的成績完全依賴于碼,而其它非主屬性對碼的函 數依賴為部分函數依賴,所以不屬于 2NF。 消除非主屬性對碼的函數依賴為部分函數依賴,將關系模式分解成 2NF 如下: S1(Sno,Sname,SD,Sdname) S2(Sno,Course,Grade) (3)將關系模式分解成 3NF,并說明為什么? 答: 將上述關系模式分解成 3NF 如下: 關系模式 S1 中存在 SnoSD,SDSdname,即非主屬性 Sdname 傳遞

17、依賴于 Sno,所以 S1 不是 3NF。進一步分如下: S11(Sno,Sname,SD) S12(SD,Sdname) 分解后的關系模式 S11、S12 滿足 3NF。 對關系模式 S2 不存在非主屬性對碼的傳遞依賴,故屬于 3NF。所以,原模式 S(Sno,Sname,SD,Sdname,Course,Grade)按如下分解滿足 3NF。 S11(Sno,Sname,SD) S12(SD,Sdname) S2(Sno,Course,Grade) P P (1) 一個學生可選修多門課程,一門課程可為多個學生選修;(2) 一個教師可講授多門課程,一門課程可為多個 教師講授;(3) 一個單位可

18、有多個教師,一個教師只能屬于一個單位。 試完成如下工作:(1) 分別設計學生選課和教師任課兩個局部信息的結構 E-R 圖。 (2) 將上述設計完成的 E-R 圖合并成一個全局 E-R 圖。 (3) 將該全局 E-R 圖轉換為等價的關系模型表示的數據庫邏輯結構。 解:(1) 學生選課、教師任課局部 E-R 圖如下所示。 (2) 合并后的全局 E-R 圖如下所示。 開課 單位 課程選修 學生 擁有 姓名性別學號課程名 教師號 編號 單位名 年齡 1 1 m mn m 學生選課局部 E-R 圖 教師 課程 講授 單位 屬于 單位名電話 編號 姓名性別教師號年齡 mn m 1 教師授課局部 E-R 圖 屬于 單位 課程 選修學生 擁有 教師 開課 講授 1 1 1 m m m n n m m 全局 E-R 圖 3、請設計一個圖書館數據庫,

溫馨提示

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

評論

0/150

提交評論