資料庫設計正規化理解

2021-09-29 08:29:17 字數 1440 閱讀 6875

看書的時候有一點迷不好理解,所以找了個時間查了一下。

參考文件:

設計關聯式資料庫時,遵從不同的規範要求,設計出合理的關係型資料庫,這些不同的規範要求被稱為不同的正規化,各種正規化呈遞次規範,越高的正規化資料庫冗餘越小。

目前關聯式資料庫有六種正規化:第一正規化(1nf)、第二正規化(2nf)、第三正規化(3nf)、巴斯-科德正規化(bcnf)、第四正規化(4nf)和第五正規化(5nf,還又稱完美正規化)。

所謂第一正規化(1nf)是指在關係模型中,對域新增的乙個規範要求,所有的域都應該是原子性的,即資料庫表的每一列都是不可分割的原子資料項,而不能是集合,陣列,記錄等非原子資料項。即實體中的某個屬性有多個值時,必須拆分為不同的屬性。在符合第一正規化(1nf)表中的每個域值只能是實體的乙個屬性或乙個屬性的一部分。簡而言之,第一正規化就是無重複的域。

總結來說,

目的:確保每列保持原子性

表現:不能再拆分出列的表。

在1nf的基礎上,非碼屬性必須完避全依賴於碼[在1nf基礎上消除非主屬性對主碼的部分函式依賴]。第二正規化(2nf)是在第一正規化(1nf)的基礎上建立起來的,即滿足第二正規化(2nf)必須先滿足第一正規化(1nf)。

第二正規化(2nf)要求資料庫表中的每個例項或記錄必須可以被唯一地區分。選取乙個能區分每個實體的屬性或屬性組,作為實體的唯一標識。

第二正規化(2nf)要求實體的屬性完全依賴於主關鍵字。所謂完全依賴是指不能存在僅依賴主關鍵字一部分的屬性,如果存在,那麼這個屬性和主關鍵字的這一部分應該分離出來形成乙個新的實體,新實體與原實體之間是一對多的關係。為實現區分通常需要為表加上乙個列,以儲存各個例項的唯一標識。簡而言之,第二正規化就是在第一正規化的基礎上屬性完全依賴於主鍵。

在1nf基礎上,任何非主屬性不依賴於其它非主屬性[在2nf基礎上消除傳遞依賴]

第三正規化(3nf)是第二正規化(2nf)的乙個子集,即滿足第三正規化(3nf)必須滿足第二正規化(2nf)。簡而言之,第三正規化(3nf)要求乙個關係中不包含已在其它關係已包含的非主關鍵字資訊。

在1nf基礎上,任何非主屬性不能對主鍵子集依賴[在3nf基礎上消除對主碼子集的依賴]巴德斯科正規化(bcnf)是第三正規化(3nf)的乙個子集,即滿足巴斯-科德正規化(bcnf)必須滿足第三正規化(3nf)。通常情況下,巴斯-科德正規化被認為沒有新的設計規範加入,只是對第二正規化與第三正規化中設計規範要求更強,因而被認為是修正第三正規化,也就是說,它事實上是對第三正規化的修正,使資料庫冗餘度更小。這也是bcnf不被稱為第四正規化的原因。某些書上,根據正規化要求的遞增性將其稱之為第四正規化是不規範,也是更讓人不容易理解的地方。而真正的第四正規化,則是在設計規範中新增了對多值及依賴的要求。

對於bcnf,在主碼的任何乙個真子集都不能決定於主屬性。關係中u主碼,若u中的任何乙個真子集x都不能決定於主屬性y,則該設計規範屬性bcnf。

第四正規化:要求把同一表內的多對多關係刪除。

第五正規化:從最終結構重新建立原始結構。

結合參考文件的例子看,會更清晰一些。

以及,資料庫真的還用到的挺多的很值得學習一下。

資料庫設計正規化的理解

前言 為什麼要寫這篇文章呢,從去年年底開始,就和很多做技術的朋友交流過,從資料庫設計到資料庫架構各個方面的內容。有一些朋友執著於orm,執著於所謂的資料庫設計,卻忘記了一切技術是要為業務服務這個基石。當然這文章裡也有一些自己的理解,想向大家表達。正規化是什麼 正規化是符合某一種級別的關係模式的集合。...

資料庫設計正規化的理解

正規化是什麼 正規化是符合某一種級別的關係模式的集合。關聯式資料庫中的關係必須滿足一定的要求,即滿足不同的正規化。目前關聯式資料庫有六種正規化 第一正規化 1nf 第二正規化 2nf 第三正規化 3nf 第四正規化 4nf 第五正規化 5nf 和第六正規化 6nf 滿足最低要求的正規化是第一正規化 ...

資料庫設計三正規化理解

在網上查詢一些資料,加上自己的理解做了一些筆記 這是設計表的依據,按照三正規化設計的表不會出現資料冗餘。正規化說明 第一正規化 1nf 每乙個表都需要有主鍵,每乙個欄位的具有原子性,不可再分 第二正規化 2nf 有主鍵,非主鍵字段完全依賴主鍵,不能產生部分依賴 第三正規化 3nf 非主鍵字段不能相互...