簡單的理解資料庫三正規化

2021-07-10 09:26:07 字數 1443 閱讀 4051

正規化:英文名稱是 normal form,它是英國人 e.f.codd(關聯式資料庫的老祖宗)在上個世紀70年代提出關聯式資料庫模型後總結出來的,正規化是關聯式資料庫理論的基礎,也是我們在設計資料庫結構過程中所要遵循的規則和指導方法。目前有跡可尋的共有8種正規化,依次是:1nf,2nf,3nf,bcnf,4nf,5nf,dknf,6nf。通常所用到的只是前三個正規化,即:第一正規化(1nf),第二正規化(2nf),第三正規化(3nf)。下面就簡單介紹下這三個正規化。 

1nf:字段不可分; 

2nf:有主鍵,非主鍵字段依賴主鍵; 

3nf:非主鍵字段不能相互依賴; 

解釋: 

1nf:原子性 字段不可再分,否則就不是關聯式資料庫; 

2nf:唯一性 乙個表只說明乙個事物; 

3nf:每列都與主鍵有直接關係,不存在傳遞依賴; 

不符合第一正規化的例子(關聯式資料庫中create不出這樣的表): 

表:欄位1, 欄位2(欄位2.1, 欄位2.2), 欄位3 ...... 

存在的問題: 因為設計不出這樣的表, 所以沒有問題; 

不符合第二正規化的例子: 

表:學號, 姓名, 年齡, 課程名稱, 成績, 學分; 

這個表明顯說明了兩個事務:學生資訊, 課程資訊; 

存在問題: 

資料冗餘,每條記錄都含有相同資訊; 

刪除異常:刪除所有學生成績,就把課程資訊全刪除了; 

插入異常:學生未選課,無法記錄進資料庫; 

更新異常:調整課程學分,所有行都調整。 

修正: 

學生:student(學號, 姓名, 年齡); 

課程:course(課程名稱, 學分); 

選課關係:selectcourse(學號, 課程名稱, 成績)。 

滿足第2正規化只消除了插入異常。 

不符合第三正規化的例子: 

學號, 姓名, 年齡, 所在學院, 學院聯絡**,關鍵字為單一關鍵字"學號"; 

存在依賴傳遞: (學號) → (所在學院) → (學院地點, 學院**) 

存在問題: 

資料冗餘:有重複值; 

更新異常:有重複的冗餘資訊,修改時需要同時修改多條記錄,否則會出現資料不一致的情況 

刪除異常 

修正: 

學生:(學號, 姓名, 年齡, 所在學院); 

學院:(學院, 地點, **)。 

依賴:由..決定;依賴主鍵:由主鍵決定。

關於如何區分乙個正規化是違反2nf還是3nf(雖然沒什麼意義,但是新人都會迷惑):

違反2nf,不滿足都依賴主鍵的原則,如上面例子,學分不是由學號(學生)決定的。由於有屬性不依賴主鍵,所以一般需要分成3(嚴格說是n+1)個表,2個事物加乙個關係。違反2nf必然違反3nf,但是通常說法是違反2nf;

違反3nf(已經滿足2nf),即違反非主鍵之間有依賴關係,但是因為已經滿足2nf(所有非主鍵都依賴主鍵),所以一般分為2(n)個表,2個事物。

簡單理解資料庫三大正規化

書上講了好多,歸結起來3句話 1nf 字段不可分 2nf 有主鍵,非主鍵字段依賴主鍵 3nf 非主鍵字段不能相互依賴 解釋 1nf 原子性 字段不可再分,否則就不是關聯式資料庫 2nf 唯一性 乙個表只說明乙個事物 3nf 每列都與主鍵有直接關係,不存在傳遞依賴 不符合第一正規化的例子 關聯式資料庫...

mysql資料庫的正規化 理解資料庫正規化

第一正規化 1nf 第一正規化的核心描述為 資料庫表的每一列都是不可分割的基本資料項,同一列中不能有多個值。該正規化講的是列的原子性。有兩層意思 一層是說每一列只能存乙個屬性值 如果把2個屬性值存在1列中 第二層說的是在一張表中屬性值不能重複。在現代關係行資料庫中,都是預設滿足第一正規化的,所以你想...

深入MySL 理解資料庫三正規化

資料庫的設計正規化是資料庫設計所需要滿足的規範,滿足這些規範的資料庫是簡潔的 結構明晰的,同時,不會發生插入 insert 刪除 delete 和更新 update 操作異常。反之則是亂七八糟,不僅給資料庫的程式設計人員製造麻煩,而且面目可憎,可能儲存了大量不需要的冗餘資訊 如下的資料庫表是符合第一...