亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

數據庫設計范式深入淺出

系統 1619 0
?                數據庫設計范式深入淺出

  關系數據庫設計之時是要遵守一定的規則的。尤其是數據庫設計范式 現簡單介紹 1NF (第一范式), 2NF (第二范式), 3NF (第三范式)和 BCNF ,另有第四范式和第五范式留到以后再介紹。 在你設計數據庫之時,若能符合這幾個范式,你就是數據庫設計的高手。

第一范式( 1NF ): 在關系模式 R 中的每一個具體關系 r 中,如果每個屬性值 都是不可再分的最小數據單位,則稱 R 是第一范式的關系。例:如職工號,姓名,電話號碼組成一個表(一個人可能有一個辦公室電話 和一個家里電話號碼) 規范成為 1NF 有三種方法:

一是重復存儲職工號和姓名。這樣,關鍵字只能是電話號碼。

二是職工號為關鍵字,電話號碼分為單位電話和住宅電話兩個屬性

三是職工號為關鍵字,但強制每條記錄只能有一個電話號碼。

以上三個方法,第一種方法最不可取,按實際情況選取后兩種情況。

第二范式( 2NF ): 如果關系模式 R U F )中的所有非主屬性都完全依賴于任意一個候選關鍵字,則稱關系 R 是屬于第二范式的。

例:選課關系 SCI SNO CNO GRADE CREDIT )其中 SNO 為學號, CNO 為課程號, GRADEGE 為成績, CREDIT 為學分。 由以上條件,關鍵字為組合關鍵字( SNO CNO

在應用中使用以上關系模式有以下問題:

a.
數據冗余,假設同一門課由 40 個學生選修,學分就 重復 40 次。

b.
更新異常,若調整了某課程的學分,相應的元組 CREDIT 值都要更新,有可能會出現同一門課學分不同。

c.
插入異常,如計劃開新課,由于沒人選修,沒有學號關鍵字,只能等有人選修才能把課程和學分存入。

d.
刪除異常,若學生已經結業,從當前數據庫刪除選修記錄。某些門課程新生尚未選修,則此門課程及學分記錄無法保存。

原因:非關鍵字屬性 CREDIT 僅函數依賴于 CNO ,也就是 CREDIT 部分依賴組合關鍵字( SNO CNO )而不是完全依賴。

解決方法:分成兩個關系模式 SC1 SNO CNO GRADE ), C2 CNO CREDIT )。新關系包括兩個關系模式,它們之間通過 SC1 中的外關鍵字 CNO 相聯系,需要時再進行自然聯接,恢復了原來的關系

第三范式( 3NF ): 如果關系模式 R U F )中的所有非主屬性對任何候選關鍵字都不存在傳遞信賴,則稱關系 R 是屬于第三范式的。

例:如 S1 SNO SNAME DNO DNAME LOCATION 各屬性分別代表學號,

姓名,所在系,系名稱,系地址。

關鍵字 SNO 決定各個屬性。由于是單個關鍵字,沒有部分依賴的問題,肯定是 2NF 。但這關系肯定有大量的冗余,有關學生所在的幾個屬性 DNO DNAME LOCATION 將重復存儲,插入,刪除和修改時也將產生類似以上例的情況。

原因:關系中存在傳遞依賴造成的。即 SNO -> DNO DNO -> SNO 卻不存在, DNO -> LOCATION, 因此關鍵遼 SNO LOCATION 函數決定是通過傳遞依賴 SNO -> LOCATION 實現的。也就是說, SNO 不直接決定非主屬性 LOCATION

解決目地:每個關系模式中不能留有傳遞依賴。

解決方法:分為兩個關系 S SNO SNAME DNO ), D DNO DNAME LOCATION

注意:關系 S 中不能沒有外關鍵字 DNO 。否則兩個關系之間失去聯系。

BCNF :如果關系模式 R U F )的所有屬性(包括主屬性和非主屬性)都不傳遞依賴于 R 的任何候選關鍵字,那么稱關系 R 是屬于 BCNF 的。或是關系模式 R ,如果每個決定因素都包含關鍵字(而不是被關鍵字所包含),則 RCNF 的關系模式。

例:配件管理關系模式 WPE WNO PNO ENO QNT )分別表倉庫號,配件號,職工號,數量。有以下條件

a.
一個倉庫有多個職工。

b.
一個職工僅在一個倉庫工作。

c.
每個倉庫里一種型號的配件由專人負責,但一個人可以管理幾種配件。

d.
同一種型號的配件可以分放在幾個倉庫中。

分析:由以上得 PNO 不能確定 QNT ,由組合屬性( WNO PNO )來決定,存在函數依賴( WNO PNO -> ENO 。由于每個倉庫里的一種配件由專人負責,而一個人可以管理幾種配件,所以有組合屬性( WNO PNO )才能確定負責人,有( WNO PNO -> ENO 。因為 一個職工僅在一個倉庫工作,有 ENO -> WNO 。由于每個倉庫里的一種配件由專人負責,而一個職工僅在一個倉庫工作,有 ENO PNO -> QNT

找一下候選關鍵字,因為( WNO PNO -> QNT ,( WNO PNO -> ENO ,因此 WNO PNO )可以決定整個元組,是一個候選關鍵字。根據 ENO->WNO ,( ENO PNO ->QNT ,故( ENO PNO )也能決定整個元組,為另一個候選關鍵字。屬性 ENO WNO PNO 均為主屬性,只有一個非主屬性 QNT 。它對任何一個候選關鍵字都是完全函數依賴的,并且是直接依賴,所以該關系模式是 3NF

分析一下主屬性。因為 ENO->WNO ,主屬性 ENO WNO 的決定因素,但是它本身不是關鍵字,只是組合關鍵字的一部分。這就造成主屬性 WNO 對另外一個候選關鍵字( ENO PNO )的部 分依賴,因為( ENO PNO -> ENO 但反過來不成立,而 P->WNO ,故( ENO PNO -> WNO 也是傳遞依賴。

雖然沒有非主屬性對候選關鍵遼的傳遞依賴,但存在主屬性對候選關鍵字的傳遞依賴,同樣也會帶來麻煩。如一個新職工分配到倉庫工作,但暫時處于實習階段,沒有獨立負責對某些配件的管理任務。由于缺少關鍵字的一部分 PNO 而無法插入到該關系中去。又如某個人改成不管配件了去負責安全,則在刪除配件的同時該職工也會被刪除。

解決辦法:分成管理 EP ENO PNO QNT ),關鍵字是( ENO PNO )工作 EW ENO WNO )其關鍵字是 ENO

缺點:分解后函數依賴的保持性較差。如此例中,由于分解 , 函數依賴( WNO PNO -> ENO 丟失了 , 因而對原來的語義有所破壞。沒有體現出每個倉庫里一種部件由專人負責。有可能出現 一部件由兩個人或兩個以上的人來同時管理。因此,分解之后的關系模式降低了部分完整性約束。

一個關系分解成多個關系,要使得分解有意義,起碼的要求是分解后不丟失原來的信息。這些信息不僅包括數據本身,而且包括由函數依賴所表示的數據之間的相互制約。進行分解的目標是達到更高一級的規范化程度,但是分解的同時必須考慮兩個問題:無損聯接性和保持函數依賴。有時往往不可能做到既有無損聯接性,又完全保持函數依賴。需要根據需要進行權衡。

1NF 直到 BCNF 的四種范式之間有如下關系:

BCNF
包含了 3NF 包含 2NF 包含 1NF

小結:

目地:規范化目的是使結構更合理,消除存儲異常,使數據冗余盡量小,便于插入、刪除和更新

原則:遵從概念單一化 ' 一事一地 ' 原則,即一個關系模式描述一個實體或實體間的一種聯系。規范的實質就是概念的單一化。

方法:將關系模式投影分解成兩個或兩個以上的關系模式。

要求:分解后的關系模式集合應當與原關系模式 ' 等價 ' ,即經過自然聯接可以恢復原關系而不丟失信息,并保持屬性間合理的聯系。

注意:一個關系模式結這分解可以得到不同關系模式集合,也就是說分解方法不是唯一的。最小冗余的要求必須以分解后的數據庫能夠表達原來數據庫所有信息為前提來實現。其根本目標是節省存儲空間,避免數據不一致性,提高對關系的操作效率,同時滿足應用需求。實際上,并不一定要求全部模式都達到 BCNF 不可。有時故意保留部分冗余可能更方便數據查詢。尤其對于那些更新頻度不高,查詢頻度極高的數據庫系統更是如此。

在關系數據庫中,除了函數依賴之外還有多值依賴,聯接依賴的問題,從而提出了第四范式,第五范式等更高一級的規范化要求。在此,以后再談。

各位朋友,你看過后有何感想,其實,任何一本數據庫基礎理論的書都會講這些東西,考慮到很多網友是半途出家,來做數據庫。特找一本書大抄特抄一把,各位有什么問題,也別問我了,自已去找一本關系數據庫理論的書去看吧,說不定,對各位大有幫助。說是說以上是基礎理論的東西,請大家想想,你在做數據庫設計的時候有沒有考慮過遵過以上幾個范式呢,有沒有在數據庫設計做得不好之時,想一想,對比以上所講,到底是違反了第幾個范式呢?

我見過的數據庫設計,很少有人做到很符合以上幾個范式的,一般說來,第一范式大家都可以遵守,完全遵守第二第三范式的人很少了,遵守的人一定就是設計數據庫的高手了, BCNF 的范式出現機會較少,而且會破壞完整性,你可以在做設計之時不考慮它,當然在 ORACLE 中可通過觸發器解決其缺點。以后我們共同做設計之時,也希望大家遵守以上幾個范式。

數據庫設計范式深入淺出


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 免费不卡 | 精品久久免费观看 | 久久这里只精品热免费99 | 午夜伦4480yy妇女久久久 | 亚洲国产精品综合久久 | 色婷婷一区二区三区四区成人 | 成年女人a毛片免费视频 | 成熟的女性强烈交性视频 | 在线观看偷拍视频一区 | 久久精品国产74国产 | 九九99久久精品午夜剧场免费 | 在线中文字幕一区 | 久久国产综合精品欧美 | 国产成人精品日本亚洲麻豆 | 欧美激情视频一区 | 国产日韩一区二区三区在线观看 | 亚洲人成网i8禁止 | 国产一区二区三区四 | 97视频在线观看免费视频 | 国语性猛交xxxx乱大交 | 男人天堂视频网 | 性色生活免费看性大片 | 亚洲视频在线一区二区三区 | 亚洲一区二区三区首页 | 日韩欧美在线播放视频 | 国产精品成在线观看 | 日韩操 | 成人欧美午夜视频毛片 | 日本中文字幕永久在线 | 久久久久欧美精品 | 免费一级毛片在播放视频 | 91视频免费播放 | 狠狠色婷婷丁香综合久久韩国 | 亚洲免费一级视频 | 久久精品视频8 | 毛片网站免费在线观看 | 国产v欧美v日韩在线观看 | 亚洲欧美精品综合中文字幕 | 爱爱小视频成人免费 | 国产在线91区精品 | 毛片午夜 |