1

我得到了以下结构 - 我承认这并不理想,但有很多东西是建立在此之上的,我想尽量减少变化。
我不确定如何正确实现 Documents 和 Delivery Adresses 之间的引用完整性。可以在这里完成而不使用触发器吗?问题是在文档中 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
4

1 回答 1

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外键引用。

于 2013-06-14T08:59:19.863 回答