6、数据库设计为什么要使用三大范式
本節(jié)主要介紹不使用三大范式會(huì)對(duì)設(shè)計(jì)數(shù)據(jù)庫有什么影響,會(huì)出現(xiàn)什么問題。
這里可以將三大范式理解為:設(shè)計(jì)數(shù)據(jù)庫時(shí)需要遵循的規(guī)則,可以有效的幫助我們建立冗余小且結(jié)構(gòu)合理的數(shù)據(jù)庫。
在概要設(shè)計(jì)階段,同一個(gè)項(xiàng)目,10 個(gè)設(shè)計(jì)人員可能設(shè)計(jì)出 10 種不同的 E-R 圖。不同的角度可以標(biāo)識(shí)出不同的實(shí)體,實(shí)體又包括不同的屬性,自然就設(shè)計(jì)出了不同的 E-R圖。那么怎樣審核這些設(shè)計(jì)圖呢?如何評(píng)審出最優(yōu)的設(shè)計(jì)方案呢?答案就藏在后面的內(nèi)容里。
下面以某酒店的客人住宿信息表為例來介紹,該表用于保存酒店提供住宿的客房信息,如表 1 所示。
從用戶的角度來說,將所有信息放在一個(gè)表中很方便,因?yàn)檫@樣查詢數(shù)據(jù)庫可能會(huì)比較容易,但是上述表具有下列問題。
1. 信息重復(fù)(冗余)
上表中“客房類型”“客房狀態(tài)”和“床位數(shù)”列中有許多重復(fù)的信息,如“標(biāo)準(zhǔn)間”“入住”等。信息重復(fù)會(huì)造成存儲(chǔ)空間的浪費(fèi)及一些其他的問題。比如,不小心輸入了“標(biāo)準(zhǔn)間”和“標(biāo)間”或“總統(tǒng)套房”和“總統(tǒng)套”,那么它們?cè)跀?shù)據(jù)庫中將表示四種不同的客房類型。
2. 更新異常
冗余信息不僅浪費(fèi)存儲(chǔ)空間,還會(huì)增加更新的難度。如果需要將“客房類型”修改為“標(biāo)間”而不是“標(biāo)準(zhǔn)間”,則需要修改所有包含該值的行。如果由于某種原因,沒有更新所有行,那么數(shù)據(jù)庫中會(huì)出現(xiàn)兩種客房類型,一個(gè)是“標(biāo)準(zhǔn)間”,另一個(gè)是“標(biāo)間”,這種情況被稱為更新異常。
3. 插入異常(無法表示某些信息)
從表 1 中我們會(huì)發(fā)現(xiàn) 2002 和 2003 客房的居住價(jià)格分別是 168 元和 158 元。盡管這兩間客房都是標(biāo)準(zhǔn)間類型,但它們的“價(jià)格”出現(xiàn)了不同,這樣就造成了同一個(gè)酒店相同類型的客房價(jià)格不同,這種問題被稱為插入異常。
4. 刪除異常(丟失有用的信息)
在某些情況下,當(dāng)刪除一行時(shí),可能會(huì)丟失有用的信息。例如,如果刪除客房類型為“1001”的行,就會(huì)丟失客房類型為“單人間”的賬戶的信息,該表只剩下兩種客房類型,即“標(biāo)準(zhǔn)間”和“總統(tǒng)套房”。當(dāng)查詢有哪些客房類型時(shí),將會(huì)誤以為只有“標(biāo)準(zhǔn)間”和“總統(tǒng)套房”兩種客房類型,這種情況被稱為刪除異常。
總結(jié)
以上是生活随笔為你收集整理的6、数据库设计为什么要使用三大范式的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 5、数据库设计的三大范式
- 下一篇: 1、MySQL数据类型简介