今天执行SQL语句的时候,遇到了“违反唯一约束”的错误,找了半天,才发现问题所在。
通常遇到这个问题是在执行表的插入的时候遇到的。
建表语句如下:
CREATE TABLE dbo.scheduletable
(
scheduleid numeric(9,0) NOT NULL,
agentid varchar(32) NOT NULL,
agentname varchar(20) NULL,
shiftdate char(10) NOT NULL,
shiftid int NOT NULL,
status int NULL,
CONSTRAINT PK_SCHEDULETABLE
PRIMARY KEY CLUSTERED (scheduleid,agentid,shiftdate)
)
加入你已经插入了一条如下的语句:
insert into wf_scheduletable (scheduleid,agentid,agentname,shiftdate,shiftid,status)
values(11,'8077','黄文','2011-10-30',3,0);
如果你在插入下面的语句:
insert into wf_scheduletable (scheduleid,agentid,agentname,shiftdate,shiftid,status)
values(11,'8077','何冰','2011-10-30',3,1);
就会出现上面的错误。
是主键的原因,要注意到该表的主键是3个,所以插入的数据不能一样。