詳細講解如何將數據模型轉換成數據庫設計

字號:

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