詳細講解如何將數據模型轉換成數據庫設計
將數據模型轉換成數據庫設計的相關問題:
1.創建表的聯系
1:1強實體聯系:
把一個表的主鍵作為另一張表的外鍵。為了強調***粒度是1,應該把外鍵設置成候選鍵。
1:N強實體聯系:
把1的那一段的表(父表)的鍵設置成對應N的那一端的表(子表)的外鍵。
N:M強實體聯系:
建立只包含外鍵的第三張交關系表,這個表中每一列都是主鍵的一部分,每一列都對應于其他表外鍵,因此他總是ID依賴于它的兩個父表。
注意,這張交關系表中,必須要有父表中的行。
2.使用ID依賴實體聯系的其他方法
關聯聯系:
這種聯系只針對聯系本身,而不是實體的屬性。只需建立一張關聯表,ID依賴于兩張父表,并包含父表的聯系屬性,如公司和貨物的:Price。
注意,關聯表和交關系表的最重要區別是關聯表含有用戶數據,而交關系表則沒有。
多值屬性:
用ID依賴實體代表父表所含有的多值組合,如CompanyName的(Contact, PhoneNumber),PhoneNumber可含有多個值。CompanyName在新表中將既是主鍵又是外鍵。
原型/實例模式:
當一個ID依賴實體的父實體使用強制關鍵字時,ID依賴實體也使用自己的強制關鍵字。得到的結果是弱實體,擔不是ID依賴實體。
3.混合實體聯系
這種設計既包含強實體設計也包含ID依賴實體的設計。
對HAS-A聯系進行轉換時,總的原則是“把父表的鍵放到子表中”,通常把1對應的父表放到子表中,N:M聯系先轉換成兩個1:N聯系。而對于標識聯系,父表的鍵已經在子表中了,所以什么都不用做。對于混合聯系中的非標識聯系,父表的鍵放在子表中。
4.子類型 IS-A聯系
子表和父表的主鍵相同,且子表的主鍵也是外鍵。
5.遞歸聯系
1:1
在表中創建一個外鍵并設為候選鍵,指向父表。此表中父表和子表均是其自身。
1:N
通過把父表的鍵放到子表中來標識1:N遞歸聯系。
N:M
創建一個交關系表,把它分解成兩個1:N聯系。
本文就簡單為大家總結這五點,思路也比較清晰明了,易于大家去學習掌握,希望能夠對大家有所幫助。
【編輯推薦】