表中联合主键的问题
MSSQL 2008中,一张表已有一个主键pk_a,现在想将另外一列b,也设置为主键形成双主键,并且主键pk_a被其他表引用了外键,
请问这个时候怎么设置联合主键??
请看源码:
SQL code
CREATE TABLE test1
(a VARCHAR(20) NOT NULL ,
b VARCHAR(20) NULL,
c VARCHAR(20) NULL,
CONSTRAINT pk_a PRIMARY KEY (a)
);
CREATE TABLE test2
( a VARCHAR(20) NOT NULL ,
t1 INT NULL ,
t2 VARCHAR(20),
CONSTRAINT fk_a FOREIGN KEY (a) REFERENCES test1(a)
);
------解决方案--------------------SQL code
alter table #t
add constraint 约束名 primary key (字段1,字段2)
------解决方案--------------------
你说的是候选键吧。一个表只能一个主键。
你在b列加一个唯一约束就可以了。
------解决方案--------------------
你是要把主键a 改成联合主键 ab?
然后 领一个表值外键a
------解决方案--------------------
------解决方案--------------------
删除主键,再重新创建复合主键。。。
------解决方案--------------------