如何添加sql表的唯一约束作为sql server 2005中另一个sql表的外键引用
答案 0 :(得分:8)
为了添加FK约束(在子表中添加父表),您必须向父表关系列添加唯一约束。
所有其余的都是可选的或与FK无关:
父表(在这种FK关系中)经常被调用(包括SSMS)作为主键表,但PK不是必须的,父表中的唯一键/约束就足够了(因为PK是唯一的,它是特殊的情况)父表中的唯一约束)。
从answer by Matt删除TableA和TableB,这对初学者来说很困惑,
并将它们重新创建为
CREATE TABLE parentB--TableB
(
PK1 INT NOT NULL,
PK2 INT NOT NULL,
--I would not have additional non-referenced data in parent table,
--rather in child table
--SomeData VARCHAR(1000),
--CONSTRAINT PK_TableB PRIMARY KEY CLUSTERED (PK1, PK2)
)
CREATE TABLE childA--TableA
(
--PK INT, -- NOT NULL,
FK1 INT-- NOT NULL, -- Or NULL, if you''d rather.
FK2 INT --NOT NULL --,
, SomeData VARCHAR(1000)
--CONSTRAINT PK_TableA PRIMARY KEY CLUSTERED (PK),
--CONSTRAINT FK_TableA_FK1FK2 FOREIGN KEY (FK1, FK2) REFERENCES TableB (PK1, PK2),
--CONSTRAINT Cons2cols UNIQUE(FK1, FK2)
)
现在,按顺序添加FK
ALTER TABLE childA
ADD
--constraint FK1_childA
--this is optional, if one needs to add his own custom name
FOREIGN KEY (FK1) REFERENCES parentB(PK1);
您应首先在父表列中的相应引用列上创建唯一约束:
ALTER TABLE parentB ADD
--CONSTRAINT YourUniqueName --uncomment for adding your own name to constraint
UNIQUE(PK1)
类似于2列外键约束
(首先,在父表中需要相应的唯一约束):
ALTER TABLE parentB ADD
--CONSTRAINT YourUniqueName --for adding your own name to unique constraint
UNIQUE(PK1,PK2)
ALTER TABLE childA
ADD
--constraint yourUniqueName --uncomment for adding your own name to FK constraint
FOREIGN KEY (FK1, FK2) REFERENCES parentB(PK1, PK2);
答案 1 :(得分:1)
如果您从头开始创建表,则其工作原理如下:
CREATE TABLE TableB (
PK1 INT NOT NULL,
PK2 INT NOT NULL,
SomeData VARCHAR(1000),
CONSTRAINT PK_TableB PRIMARY KEY CLUSTERED (PK1, PK2)
)
CREATE TABLE TableA (
PK INT NOT NULL,
FK1 INT NOT NULL, -- Or NULL, if you''d rather.
FK2 INT NOT NULL,
CONSTRAINT PK_TableA PRIMARY KEY CLUSTERED (PK),
CONSTRAINT FK_TableA_FK1FK2 FOREIGN KEY (FK1, FK2) REFERENCES TableB (PK1, PK2),
CONSTRAINT Cons2cols UNIQUE(FK1, FK2)
)
如果表已经存在,您可以在事实之后添加这些相同的约束:
ALTER TABLE TableA ADD CONSTRAINT FK_TableA_FK1FK2 FOREIGN KEY (FK1, FK2) REFERENCES TableB (PK1, PK2);
ALTER TABLE TableA ADD CONSTRAINT Cons2cols UNIQUE(FK1, FK2);
无论哪种方式,TableA现在都有一个唯一的2列FK到另一个表。
答案 2 :(得分:0)
您需要记住,在列上添加FK不会自动在该列上添加索引。您需要分两步完成此操作。
1) Make a column in your table a FK to a parent table.
2) Add a unique constraint on that same column
答案 3 :(得分:0)
忘掉现在的独特约束。只需在两列上创建新的外键。
ALTER TABLE dbo.PurchaseDetail
ADD FOREIGN KEY (Customer, Product)
REFERENCES dbo.Purchase (Customer, Product)
答案 4 :(得分:0)
我更喜欢这种方法,其中该表引用了另一个表(transaction_log):
CREATE TABLE transaction_settings_log
(
transaction_fk UUID NOT NULL
CONSTRAINT transaction_log_pkey REFERENCES transaction_log (id) UNIQUE,
group_selected BOOLEAN DEFAULT TRUE,
leg_closed BOOLEAN DEFAULT FALSE
);