第三規範化

要求所有非主鍵都只和候選鍵有關聯的資料庫正規化形式

第三範式(3NF)是資料庫規範化所使用的正規形式,要求所有非主鍵屬性都只和候選鍵有相關性,也就是說非主鍵屬性之間應該是獨立無關的。

如果再對第三範式做進一步加強就成了BC範式,強調的重點在於「資料間的關係是奠基在主鍵上、以整個主鍵為考量、而且除了主鍵之外不考慮其他因素」。

正規定義

編輯

令:

  •   表一個關係;
  •   表維持   所需的一組函數依賴
  •    屬性的子集合
  •    的一個屬性

最早由埃德加·科德在1971年給出的第三範式定義為[1]

  • 關係R(表)滿足第二範式 (2NF);
  • R的每個非鍵屬性是R的每個候選鍵的非傳遞依賴。

Carlo Zaniolo於1982年給出的一個等價定義為[2][3]

如果對於   這種型式的函數依賴而言,下列敘述任一為真的話,則可以稱   符合第三範式:

  •  ;也就是說  明顯函數依賴
  •  超鍵
  •   候選鍵的一部份

任何一個具有部份依賴性或是轉移依賴性的關係都違反了第三範式。

範例

編輯

以下面這個定義機械元件的關係為例:

機械元件
元件編號
(主鍵)
製造商名稱 製造商地址
1000 Toyota Park Avenue
1001 Mitsubishi Lincoln Street
1002 Toyota Park Avenue

本例中製造商地址很明顯地不該被列在這個關係裏面,因為和元件本身比起來,製造商地址應該和製造商比較有關係;正確的做法應該是把獨立出新的資料表:

製造商
製造商名稱
(主鍵)
製造商地址
Toyota Park Avenue
Mitsubishi Lincoln Street

然後把原本的資料表改成這樣:

機械元件
元件編號
(主鍵)
製造商名稱
1000 Toyota
1001 Mitsubishi
1002 Toyota

先前那個資料表的問題在於每提到一次製造商名稱就要多存一次它的地址,而這就不符合第三範式的原則。

下面提供了另一個例子:

訂單 (Order)
訂單編號(Order Number)
(主鍵)
客戶名稱 (Customer Name) 單價 (Unit Price) 數量 (Quantity) 小計 (Total)
1000 David $35.00 3 $105.00
1001 Jim $25.00 2 $50.00
1002 Bob $25.00 3 $75.00

在本例中,非主鍵字段完全依賴於主鍵訂單編號,也就是說唯一的訂單編號能導出唯一非主鍵字段值,符合第二範式。第三範式要求非主鍵字段之間不能有依賴關係,顯然本例中小計依賴於非主鍵字段「單價」和「數量」,不符合第三範式。小計不應該放在這個資料表裏面,只要把單價乘上數量就可以得到小計了;如果想要符合第三範式的話,就把小計拿掉 (不過在做查詢時, SELECT Order.Total FROM Order 需改成 SELECT UnitPrice * Quantity FROM Order )。

訂單 (Order)
訂單編號(Order Number)
(主鍵)
客戶名稱 (Customer Name) 單價 (Unit Price) 數量 (Quantity)
1000 David $35.00 3
1001 Jim $25.00 2
1002 Bob $25.00 3

參考文獻

編輯

外部連結

編輯
  1. ^ Codd, E. F. "Further Normalization of the Data Base Relational Model". (Presented at Courant Computer Science Symposia Series 6, "Data Base Systems", New York City, May 24–25, 1971.) IBM Research Report RJ909 (August 31, 1971). Republished in Randall J. Rustin (ed.), Data Base Systems: Courant Computer Science Symposia Series 6. Prentice-Hall, 1972.
  2. ^ Zaniolo, Carlo. "A New Normal Form for the Design of Relational Database Schemata". ACM Transactions on Database Systems 7(3), September 1982.
  3. ^ Abraham Silberschatz, Henry F. Korth, S. Sudarshan, Database System Concepts頁面存檔備份,存於互聯網檔案館 (5th edition), p. 276–277.