天天看點

資料庫中什麼是範式?它的作用是什麼?第一、二、三範式的内容是什麼?

構造資料庫必須遵循一定的規則。在關系資料庫中,這種規則就是範式。範式是符合某一種級别的關系模式的集合。關系資料庫中的關系必須滿足一定的要求,即滿足不同的範式。目前關系資料庫有六種範式:第一範式(1NF)、第二範式(2NF)、第三範式(3NF)、第四範式(4NF)、第五範式(5NF)和第六範式(6NF)。滿足最低要求的範式是第一範式(1NF)。在第一範式的基礎上進一步滿足更多要求的稱為第二範式(2NF),其餘範式以次類推。一般說來,資料庫隻需滿足第三範式(3NF)就行了。下面我們舉例介紹第一範式(1NF)、第二範式(2NF)和第三範式(3NF)。

3.4.1 第一範式(1NF)
    在任何一個關系資料庫中,第一範式(1NF)是對關系模式的基本要求,不滿足第一範式(1NF)的資料庫就不是關系資料庫。
    所謂第一範式(1NF)是指資料庫表的每一列都是不可分割的基本資料項,同一列中不能有多個值,即實體中的某個屬性不能有多個值或者不能有重複的屬性。如果出現重複的屬性,就可能需要定義一個新的實體,新的實體由重複的屬性構成,新實體與原實體之間為一對多關系。在第一範式(1NF)中表的每一行隻包含一個執行個體的資訊。例如,對于圖3-2 中的員工資訊表,不能将員工資訊都放在一列中顯示,也不能将其中的兩列或多列在一列中顯示;員工資訊表的每一行隻表示一個員工的資訊,一個員工的資訊在表中隻出現一次。簡而言之,第一範式就是無重複的列。

3.4.2 第二範式(2NF)
    第二範式(2NF)是在第一範式(1NF)的基礎上建立起來的,即滿足第二範式(2NF)必須先滿足第一範式(1NF)。第二範式(2NF)要求資料庫表中的每個執行個體或行必須可以被惟一地區分。為實作區分通常需要為表加上一個列,以存儲各個執行個體的惟一辨別。如
圖3-2 員工資訊表中加上了員工編号(emp_id)列,因為每個員工的員工編号是惟一的,是以每個員工可以被惟一區分。這個惟一屬性列被稱為主關鍵字或主鍵、主碼。
    第二範式(2NF)要求實體的屬性完全依賴于主關鍵字。所謂完全依賴是指不能存在僅依賴主關鍵字一部分的屬性,如果存在,那麼這個屬性和主關鍵字的這一部分應該分離出來形成一個新的實體,新實體與原實體之間是一對多的關系。為實作區分通常需要為表加上一個列,以存儲各個執行個體的惟一辨別。簡而言之,第二範式就是非主屬性非部分依賴于主關鍵字。

3.4.3 第三範式(3NF)
    滿足第三範式(3NF)必須先滿足第二範式(2NF)。簡而言之,第三範式(3NF)要求一個資料庫表中不包含已在其它表中已包含的非主關鍵字資訊。例如,存在一個部門資訊表,其中每個部門有部門編号(dept_id)、部門名稱、部門簡介等資訊。那麼在圖3-2
的員工資訊表中列出部門編号後就不能再将部門名稱、部門簡介等與部門有關的資訊再加入員工資訊表中。如果不存在部門資訊表,則根據第三範式(3NF)也應該建構它,否則就會有大量的資料備援。簡而言之,第三範式就是屬性不依賴于其它非主屬性。