今天执行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个,所以插入的数据不能一样。
本文通过实例解析了在SQL操作中遇到的“违反唯一约束”错误,并详细解释了如何避免这一问题。通过理解主键定义及其对数据插入的影响,帮助读者正确地执行SQL语句。
2072

被折叠的 条评论
为什么被折叠?



