NTU-Exam 板


LINE

課程名稱︰資料庫管理 課程性質︰資管系必修 課程教師︰孔令傑 開課學院:管理學院 開課系所︰資管系 考試日期(年月日)︰110.12.29 考試時限(分鐘):160 試題 : 1. 請依照如圖1的關聯式資料庫綱要 (relational database schema) 以及各欄位的敘述 ,利用PostgresSQL語法手寫建立三張資料表。 欄位敘述: (a) (5分) Name變動大小字元,最長10個字元、Ssn長度9的固定字元、Sex長度1的固定字 元、Dno整數。 (b) (5分) Pno整數、Essn長度9的固定字元、Hours整數。 (c) (5分) Pname變動大小字元、Pnumber長度5的固定字元、Dnum整數。 (d) (10分) 當一個員工的長官離職時,長官的社會安全碼也就是Super_ssn會被設成NULL EMPLOYEE Name | \underline{Ssn} | Sex | Super_ssn | Dno ↑ ↑ ↑ │ └─────────┘ │ WORKS_ON │ \underline{Pno} | \underline{Essn} | Hours │ └───────┐ PROJECT ↓ Pname | \underline{Pnumber} | Dnum 2. (5分) 圖2有兩張資料表,欄位為:Eid銷售員的id、Ename銷售員姓名、Salary月薪、 Dep部門編號、Pid售出產品編號、Date售出日期。請寫SQL語法找出哪位銷售員(姓名)有 賣過Pid為2的產品。 Eid | Ename | Salary | Dep Eid | Pid | Date E001 | Tom | 50000 | 2 E001 | 1 | 2021/8/9 E002 | Dennis | 30000 | 2 E001 | 2 | 2021/8/9 E002 | 1 | 2021/8/9 3. 請利用 ER diagram 針對下列情境進行資料庫塑模 (database modeling)。 情境敘述:P. LEAGUE+ 為台灣去年新創的職業籃球聯盟,執行長陳建州獻聲希望你為他建 立一個資料庫,為台灣的職籃留下相關的紀錄,下列為訪談後所得到的需求。 - A1: (5分) 每一位球員會紀錄姓名以及背號,姓名跟背號可以用來識別該球員。 - A2: (5分) 一個球員同時間只會為一支球隊打球,但可以轉隊且會紀錄該名球員在某一 隊打球開始以及結束的時間。 - A3: (5分) 每一支球隊會有唯一的球隊名稱,一個球隊會有多名球員效力。 - A4: (5分) 每一場比賽都會有該場次唯一的比賽編號,並且記錄該場次的日期、時間、 場地,每一場比賽所有參與的球員都會被紀錄。 4. (a) (10分) 請把 (31,35,7,42,6,24) 這個數列由左到右依序插入到一個原本是空的、 最多分支數為3的B+ tree中,並把最終結果畫出來。 (b) (5分) 承上題,請再插入48,並且把更新後的最終結果畫出來。 5. (15分) 當有兩張資料表A跟B要互相 inner join 的時候,有一種說法是原則上「資 料筆數較少的表放左邊、資料筆數多的表放右邊」,例如如果A的資料筆數比B多,那就 應該寫 Select * From A join B On ... 而非 Select * From B join A On ...。當然, 現代的DBMS基本上是不管你寫哪一種,它都會自己幫妳評估誰放左邊(做為 outer table)效率會比較高。 請假設DBMS在做 nested loop join,用你自己的話說明為什麼是小的表要放左邊(當 outer table),而大的要放右邊(inner table),這在simple (stupid) nested loop join是否成立,在block nested loop join又是否成立。請限制你的答案在500字以內。 6. (20分;各10分) 請考慮以下 SQL query Select C,CustomerID, S.SalesDate, S.ItemID From Customer As C Join Sales As S On C.CustomerID = S.CustomerID Where C.Birthday <= '1981-10-10' And S.SalesDate >= '2021-10-10' (a) 有一棵 query plan tree 如圖三所示。請把它改得勁量有效率,換言之,你應該畫出 一棵會產出一樣的結果但效率盡量高的 query plan tree。 π C.CustomerID, S.SaleDate, S.ItemID ↑ δ S.SalesDate >= '2021-10-10' ↑ δ C.Birthday <= '1981-10-10' ↑ ∞ C.CustomerID = S.CustomerID ↗↖ Customer As C Sales As A (b) 你可能有注意到,你並不知道Customer和Sales這兩張表誰大(雖然如無意外應該是後 者),更不知道經過篩選後是誰大。此時如果要join這兩張表,要如何決定把哪一張表當 做outer table呢?請救你上課所學說說看一個DBMS可以做些什麼事情來安排一個有效 率的query plan,以及其步驟大致為何。請限制你的答案在500字以內。 --



※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 140.112.73.129 (臺灣)
※ 文章網址: https://webptt.com/m.aspx?n=bbs/NTU-Exam/M.1643307540.A.CA1.html
1F:推 wwwh0225 : 齁 小傑P粉,怎麼不出T1呢XD 01/28 23:25
2F:推 yutaitai : P+ 是合授老師出的 XD 前三題都是 01/29 17:47
3F:推 aristoIris : 第三題是不是錯字了 XD 01/31 02:50
4F:→ aristoIris : 獻聲 -> 先生 01/31 02:50
5F:→ unmolk : 懶得改了不過還是感謝樓上xd 02/02 15:41







like.gif 您可能會有興趣的文章
icon.png[問題/行為] 貓晚上進房間會不會有憋尿問題
icon.pngRe: [閒聊] 選了錯誤的女孩成為魔法少女 XDDDDDDDDDD
icon.png[正妹] 瑞典 一張
icon.png[心得] EMS高領長版毛衣.墨小樓MC1002
icon.png[分享] 丹龍隔熱紙GE55+33+22
icon.png[問題] 清洗洗衣機
icon.png[尋物] 窗台下的空間
icon.png[閒聊] 双極の女神1 木魔爵
icon.png[售車] 新竹 1997 march 1297cc 白色 四門
icon.png[討論] 能從照片感受到攝影者心情嗎
icon.png[狂賀] 賀賀賀賀 賀!島村卯月!總選舉NO.1
icon.png[難過] 羨慕白皮膚的女生
icon.png閱讀文章
icon.png[黑特]
icon.png[問題] SBK S1安裝於安全帽位置
icon.png[分享] 舊woo100絕版開箱!!
icon.pngRe: [無言] 關於小包衛生紙
icon.png[開箱] E5-2683V3 RX480Strix 快睿C1 簡單測試
icon.png[心得] 蒼の海賊龍 地獄 執行者16PT
icon.png[售車] 1999年Virage iO 1.8EXi
icon.png[心得] 挑戰33 LV10 獅子座pt solo
icon.png[閒聊] 手把手教你不被桶之新手主購教學
icon.png[分享] Civic Type R 量產版官方照無預警流出
icon.png[售車] Golf 4 2.0 銀色 自排
icon.png[出售] Graco提籃汽座(有底座)2000元誠可議
icon.png[問題] 請問補牙材質掉了還能再補嗎?(台中半年內
icon.png[問題] 44th 單曲 生寫竟然都給重複的啊啊!
icon.png[心得] 華南紅卡/icash 核卡
icon.png[問題] 拔牙矯正這樣正常嗎
icon.png[贈送] 老莫高業 初業 102年版
icon.png[情報] 三大行動支付 本季掀戰火
icon.png[寶寶] 博客來Amos水蠟筆5/1特價五折
icon.pngRe: [心得] 新鮮人一些面試分享
icon.png[心得] 蒼の海賊龍 地獄 麒麟25PT
icon.pngRe: [閒聊] (君の名は。雷慎入) 君名二創漫畫翻譯
icon.pngRe: [閒聊] OGN中場影片:失蹤人口局 (英文字幕)
icon.png[問題] 台灣大哥大4G訊號差
icon.png[出售] [全國]全新千尋侘草LED燈, 水草

請輸入看板名稱,例如:WOW站內搜尋

TOP