如何在这里实现参照完整性?

时间:2013-06-14 08:53:55

标签: sql-server database-design

我得到了以下结构 - 我承认这种结构并不理想,但是基于这种结构,我希望尽量减少变化。
我不确定如何正确在文档和交付地址之间实现参照完整性。可以在不使用触发器的情况下完成吗?问题是addressNum有时在文档中是Null。

CREATE TABLE [dbo].[Clients](
    [IdClient] [varchar](10) NOT NULL,
    [Nom] [varchar](40) NULL
    CONSTRAINT PK_Clients PRIMARY KEY (IdClient))
GO

CREATE TABLE [dbo].[ClientsDelivAdr](
    [IdClient] [varchar](10) NOT NULL,
    [AdrNum] [tinyint] NOT NULL,
    [Adresse] [varchar](200) NULL
 CONSTRAINT [PK_ClientsAdrLivr] PRIMARY KEY (IdClient, AdrNum))

CREATE TABLE [dbo].[Documents](
    [DocID] [int] IDENTITY(1,1) NOT NULL,
    [NoDoc] [char](9) NULL,
    [IdClient] [varchar](10) NULL,
    [AdrNum] [tinyint] NULL,
    [DateDoc] [smalldatetime] NOT NULL,
 CONSTRAINT [PK_DocID] PRIMARY KEY (DocId)) 

有些客户有几个送货地址,有些没有送货地址 所以数据看起来像这样:

Clients
Id   Name     Address 
---  ----     -------
AA   ClientA  addressA
BB   ClientB  qddressB
CC   ClientC  addressC


DeliveryAdresses
Client  Adr   Address
------  ---   -------
AA      1     shop1
AA      2     shop2
CC      1     shopx

Documents
DocId   Client  Addr  OrderDate
------- ------  ----  --------
1001    CC      1     5/5/2013
1002    AA      1     5/5/2013
1003    BB     (Null) 5/5/2013

1 个答案:

答案 0 :(得分:2)

我认为您可以像预期的那样使用外键:

CREATE TABLE [dbo].[Documents](
    [DocID] [int] IDENTITY(1,1) NOT NULL,
    [NoDoc] [char](9) NULL,
    [IdClient] [varchar](10) NULL,
    [AdrNum] [tinyint] NULL,
    [DateDoc] [smalldatetime] NOT NULL,
 CONSTRAINT [PK_DocID] PRIMARY KEY (DocId),
CONSTRAINT FK_DOC_Clients FOREIGN KEY (IdClient)
     references Clients (IdClient),
CONSTRAINT FK_Doc_Addresses FOREIGN KEY (IdClient,AdrNum)
     references DeliveryAddresses (IdClient,AdrNum) ) 

如果外键引用端的一个或多个列值为NULL,则不检查外键约束。相反,没有办法让NULL成为外键引用。