PHP是一種廣泛應用于Web開發領域的編程語言,同時也是MySQL等數據庫管理系統的主要支持編程語言之一。數據庫的設計與規范一直是關注的重點,要想保證數據的一致性、準確性和完整性,需要使用數據庫設計中的三大范式,即第一范式、第二范式和第三范式。PHP也可以很好地支持這些范式,下面就來介紹一下PHP的三大范式。
第一范式一般是指數據表中的每個字段都是原子的,不可分割的。這個范式可以避免數據的重復、不一致和歧義。對于PHP來說,我們只需要保證每個表的列不再重復出現相同的數據即可。
以一個簡單的例子來說明,我們有一個名為“Users”的用戶表,里面有用戶編碼、用戶姓名、生日和性別等字段。若是最初的設計中,我們將用戶的編碼和姓名先后放在一起,如0110Alex,我們需要將其拆分成兩個字段,即用戶編碼和用戶姓名兩個字段,并以用戶編碼作為主鍵。
第二范式則是指要求在滿足第一范式的情況下,數據表中的所有非主鍵字段都與主鍵相關。也就是說,如果某個表的主鍵是由多列組成的,那么在每一個非主鍵字段都要與這個主鍵相關,才滿足第二范式。
我們仍然以用戶表為例,假設現在我們設計成了以下這樣的表結構:Users(userid, username, department, dept_info),其中,userid+username為主鍵,department為部門名稱,dept_info為部門說明。通過這個設計,我們發現,部門信息是沒有被正確“分解”的。根據第二范式,我們需要將部門字段拆分至不同表,即重新設計成兩張表,一張用戶表,一張部門表,兩個表之間建立關聯。
第三范式則是指保證在滿足第二范式的情況下,數據表中不存在非主鍵字段對主鍵字段的傳遞函數依賴。換言之,如果非主鍵字段A依賴于非主鍵字段B,而B又依賴于主鍵字段C,那么A既依賴于主鍵C,相當于函數依賴了主鍵;同上述過程,A就不能作為主鍵的一部分了。
仍然以部門表為例,我們設計的非三范式的表可能如下:
Departments(deptid,dept_name,dept_tel,manager)
其中,deptid是主鍵。但是,這個設計出了問題。假設一個管理者是經銷商,編號為1001,電話為133xxxxxxxx,則我們的dept_tel就不再與主鍵相關了。我們很難再建立需要以dept_tel為條件的查詢操作。此時我們需要將manager(即不滿足主鍵依賴)獨立出來,建立一個新表,即將Departments重新設計成如下兩張表:
Departments(deptid,dept_name,dept_tel)
Managers(deptid,manager)
使用上述三范式能夠保證數據的一致性和完整性,同時也便于數據的維護和管理。對于PHP來說,通過如上方法可以很輕松地實現數據的三范式設計。
第一范式一般是指數據表中的每個字段都是原子的,不可分割的。這個范式可以避免數據的重復、不一致和歧義。對于PHP來說,我們只需要保證每個表的列不再重復出現相同的數據即可。
以一個簡單的例子來說明,我們有一個名為“Users”的用戶表,里面有用戶編碼、用戶姓名、生日和性別等字段。若是最初的設計中,我們將用戶的編碼和姓名先后放在一起,如0110Alex,我們需要將其拆分成兩個字段,即用戶編碼和用戶姓名兩個字段,并以用戶編碼作為主鍵。
第二范式則是指要求在滿足第一范式的情況下,數據表中的所有非主鍵字段都與主鍵相關。也就是說,如果某個表的主鍵是由多列組成的,那么在每一個非主鍵字段都要與這個主鍵相關,才滿足第二范式。
我們仍然以用戶表為例,假設現在我們設計成了以下這樣的表結構:Users(userid, username, department, dept_info),其中,userid+username為主鍵,department為部門名稱,dept_info為部門說明。通過這個設計,我們發現,部門信息是沒有被正確“分解”的。根據第二范式,我們需要將部門字段拆分至不同表,即重新設計成兩張表,一張用戶表,一張部門表,兩個表之間建立關聯。
第三范式則是指保證在滿足第二范式的情況下,數據表中不存在非主鍵字段對主鍵字段的傳遞函數依賴。換言之,如果非主鍵字段A依賴于非主鍵字段B,而B又依賴于主鍵字段C,那么A既依賴于主鍵C,相當于函數依賴了主鍵;同上述過程,A就不能作為主鍵的一部分了。
仍然以部門表為例,我們設計的非三范式的表可能如下:
Departments(deptid,dept_name,dept_tel,manager)
其中,deptid是主鍵。但是,這個設計出了問題。假設一個管理者是經銷商,編號為1001,電話為133xxxxxxxx,則我們的dept_tel就不再與主鍵相關了。我們很難再建立需要以dept_tel為條件的查詢操作。此時我們需要將manager(即不滿足主鍵依賴)獨立出來,建立一個新表,即將Departments重新設計成如下兩張表:
Departments(deptid,dept_name,dept_tel)
Managers(deptid,manager)
使用上述三范式能夠保證數據的一致性和完整性,同時也便于數據的維護和管理。對于PHP來說,通過如上方法可以很輕松地實現數據的三范式設計。
下一篇php 上傳函數