一.資料庫規範化
如果資料庫沒有進行相應的規範設計,雖然在查詢資料庫可能會比較容易,但有時會造成一些問題,主要的問題如下:
1.資訊重複(會造成儲存空間的浪費及一些其他問題).
2.更新異常(冗餘資訊不僅浪費空間,還會增加更新的難度).
3.插入異常
4.刪除異常(在某些情況下,當刪除一行時,可能會丟失有用的資訊).
二.三大正規化
1.第一正規化:
目標是確保每列的原子性.如果每列都是不可再分的最小資料單元,則滿足第一正規化.
2.第二正規化:
第二正規化在第一正規化的基礎上更進一層,其目標是確保表中的每列都和主鍵相關,也就是說在乙個資料庫表中,乙個表中只能儲存一種資料,不可以把多種資料儲存在同一張資料庫表中.如果乙個關係滿足第一正規化,並且除了主鍵以外的其他列都依賴與該主鍵.則滿足第二正規化.
3.第三正規化:
第三正規化在第二正規化的基礎上更進一層,第三正規化的目標是確保每列都和主鍵列直接相關,而不是間接相關.如果乙個關係滿足第二正規化,並且除了主鍵以外的其他列都這能依賴於主鍵列,列和列之間不存在相互依賴關係,則滿足第三正規化.
1.第一正規化(1nf)
在任何乙個關聯式資料庫中,第一正規化(1nf)是對關係模式的基本要求,不滿足第一正規化(1nf)的資料庫就不是關聯式資料庫。
所謂第一正規化(1nf)是指資料庫表的每一列都是不可分割的基本資料項,同一列中不能有多個值,即實體中的某個屬性不能有多個值或者不能有重複的屬性。 如果出現重複的屬性,就可能需要定義乙個新的實體,新的實體由重複的屬性構成,新實體與原實體之間為一對多關係。在第一正規化(1nf)中表的每一行只包含 乙個例項的資訊。例如,對於員工資訊表,不能將員工資訊都放在一列中顯示,也不能將其中的兩列或多列在一列中顯示;員工資訊表的每一行只表示乙個員工的信 息,乙個員工的資訊在表中只出現一次。簡而言之,第一正規化就是無重複的列。
2.第二正規化(2nf)
第二正規化(2nf)是在第一正規化(1nf)的基礎上建立起來的,即滿足第二正規化(2nf)必須先滿足第一正規化 (1nf)。第二正規化(2nf)要求資料庫表中的每個例項或行必須可以被惟一地區分。為實現區分通常需要為表加上乙個列,以儲存各個例項的惟一標識。如 員工資訊表中加上了員工編號(emp_id)列,因為每個員工的員工編號是惟一的,因此每個員工可以被惟一區分。這個惟一屬性列被稱為主關鍵字或主鍵、主 碼。
第二正規化(2nf)要求實體的屬性完全依賴於主關鍵字。所謂完全依賴是指不能存在僅依賴主關鍵字一部分的屬性,如果存在,那麼這個屬性和 主關鍵字的這一部分應該分離出來形成乙個新的實體,新實體與原實體之間是一對多的關係。為實現區分通常需要為表加上乙個列,以儲存各個例項的惟一標識。簡 而言之,第二正規化就是非主屬性非部分依賴於主關鍵字。
3.第三正規化(3nf)
滿足第三正規化(3nf)必須先滿足第二正規化(2nf)。簡而言之,第三正規化(3nf)要求乙個資料庫表中不包含 已在其它表中已包含的非主關鍵字資訊。例如,存在乙個部門資訊表,其中每個部門有部門編號(dept_id)、部門名稱、部門簡介等資訊。那麼在員工資訊 表中列出部門編號後就不能再將部門名稱、部門簡介等與部門有關的資訊再加入員工資訊表中。如果不存在部門資訊表,則根據第三正規化(3nf)也應該構建它, 否則就會有大量的資料冗餘。簡而言之,第三正規化就是屬性不依賴於其它非主屬性。
三.規範性和效能的關係
為了滿足三大正規化,我們的資料操作效能會受到相應的影響,所以,在實際的資料庫設計中,既要考慮三大正規化,避免資料的冗餘和各種資料操作異常;有要考慮到資料訪問效能,有時,為了減少表間連線,提高資料庫的訪問效能,允許適當的資料冗餘列,這可能是最合適的資料庫設計方案.
資料庫設計三大正規化資料庫設計三大正規化
為了建立冗餘較小 結構合理的資料庫,設計資料庫時必須遵循一定的規則。在關係型資料庫中這種規則就稱為正規化。正規化是符合某一種設計要求的總結。要想設計乙個結構合理的關係型資料庫,必須滿足一定的正規化。在實際開發中最為常見的設計正規化有三個 1 第一正規化 確保每列保持原子性 第一正規化是最基本的正規化...
資料庫設計三大正規化
為了建立冗餘較小 結構合理的資料庫,設計資料庫時必須遵循一定的規則。在關係型資料庫中這種規則就稱為正規化。正規化是符合某一種設計要求的總結。要想設計乙個結構合理的關係型資料庫,必須滿足一定的正規化。在實際開發中最為常見的設計正規化有三個 1 第一正規化 確保每列保持原子性 第一正規化是最基本的正規化...
資料庫設計三大正規化
為了建立冗餘較小 結構合理的資料庫,設計資料庫時必須遵循一定的規則。在關係型資料庫中這種規則就稱為正規化。正規化是符合某一種設計要求的總結。要想設計乙個結構合理的關係型資料庫,必須滿足一定的正規化。在實際開發中最為常見的設計正規化有三個 1 第一正規化 確保每列保持原子性 第一正規化是最基本的正規化...