資料庫設計正規化深入淺出(轉)
關聯式資料庫設計之時是要遵守一定的規則的。尤其是資料庫設計正規化現簡單介紹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中可透過觸發器解決其缺點。以後我們共同做設計之時,也希望大家遵守以上幾個正規化。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/10748419/viewspace-954245/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 資料庫設計三正規化資料庫
- 資料庫表設計三正規化資料庫
- 淺談程式設計正規化程式設計
- 八、資料庫的歸約,三大正規化(規範資料庫設計)資料庫
- 關係型資料庫設計三大正規化資料庫
- 正規化(Normal Form)是資料庫設計中的概念。新的正規化(paradigm)ORM資料庫
- 資料庫設計之三正規化的的理解資料庫
- javaWeb-day03-約束、資料庫設計、正規化、資料庫備份JavaWeb資料庫
- 資料庫設計三大正規化應用例項剖析資料庫
- 資料庫建表設計六正規化介紹枘雍資料庫
- 啥是資料庫正規化資料庫
- 資料庫三正規化資料庫
- 資料庫 三大正規化資料庫
- 資料庫三大正規化資料庫
- MySQL系列資料庫設計三正規化教程示例隍啃MySql資料庫
- 資料庫正規化與例項資料庫
- 資料庫——三正規化理解資料庫
- 資料庫三大正規化 Mysql資料庫MySql
- 【一文秒懂】帶你徹底搞懂正規化與反正規化資料庫設計資料庫
- 【深入淺出ES6】字串與正規表示式字串
- 深入淺出 Viewport 設計原理View
- 深入淺出:瞭解時序資料庫 InfluxDB資料庫UX
- 資料庫中的正規化和反正規化詳解!資料庫
- 前端資料正規化化前端
- 資料庫學習(一)三正規化資料庫
- 程式設計正規化(Programmingparadigm)程式設計
- 【Perl程式設計-6】正規表示式--替換+轉化程式設計
- MySQL資料庫設計規範MySql資料庫
- Java學習筆記:資料庫中的正規化和反正規化Java筆記資料庫
- msql 資料庫設計正規化 簡單理解(1NF,2NF,3NF)SQL資料庫
- Spring的資料庫程式設計淺入淺出——不吹牛逼不裝逼Spring資料庫程式設計
- 新的Lakehouse,遲來的資料正規化轉變
- MySQL 規範 (資料庫表設計規範)MySql資料庫
- Promise拆解計劃:由規範深入,從原理淺出Promise
- 深入淺出 Java 併發程式設計 (1)Java程式設計
- 深入淺出 Java 併發程式設計 (2)Java程式設計
- MongoDB資料庫的設計規範MongoDB資料庫
- MySQL 資料庫規範--設計篇MySql資料庫
- MySQL之規範資料庫設計MySql資料庫