sql server“键列信息不足或不正确。更新影响到多行”

环境:windows server 2003 sp2,sql server 2000,用于管理固定资产的软件。html

故障现象:sql

        要同时增长两台思科交换机的固定资产信息,因为型号什么都一致,只是序列号不同。因而就想作完一台后,可否直接复制一条单据过来改一下不一致的地方就好了。可是前台没法实现。本着偷懒和学习的态度,杀到后台,直接打开数据库操做。 去了主键限制,用下面语句复制:数据库

INSERT INTO da111

SELECT *

FROM da111

WHERE (scodel = '03-ne-076')

复制完后,在结果列表中找到新复制的行,直接手动修改主键ID,想让两条语句有所区别。此时,只要鼠标点击此行之外其余地方,就提示“键列信息不足或不正确。更新影响到多行”,以下:windows

wKioL1hg3nOSX-RLAAAmjoDUtgQ650.jpg

比较崩溃的是,无论是再重装改回原来的ID值(还原成两行如出一辙),或者用删除语句删除重复,都会弹出如上警告,只有从右上角整个关闭查询分析器窗口,才能进行其余的操做。安全

缘由分析:ide

       无论是用语句,仍是用鼠标直接在表格里选中修改,其实都是update。对数据库来讲,此时等因而对两条如出一辙的行进行修改,对SQL SERVER来是不容许的。因此就会有如上提示。学习

       那么对ORACLE来讲会不会由于有ROWID的存在,就容许看上去如出一辙的行修改呢?晚点测试一下。测试

解决方法:spa

    知道缘由,解决办法就好找了。3d

    方法1.删除全部的重复行,从新手动一条条作!注意,须要关闭窗口从新打开查询分析器窗口来运行语句:

DELETE FROM da111_bak2   --也能够直接用delete da111_bak2,不加from

WHERE (scodel = '03-ne-076')

检查表相关性的时候,能够用如下窗口来检查。可是只能检查过程、触发器之类的,若是是被别的表引用,彷佛检查不出来,因此,用此方法既麻烦又不安全。

wKiom1hh0meCb4C7AAAyEHUocYU426.jpg-wh_50

wKioL1hh0mfRgfPwAAB2zkfiNiQ717.jpg-wh_50

 方法3.先删除表中主键约束,再复制行,而后用限定影响行数的方式修改其中的一行的ID,而后恢复主键约束。此法很棒,推荐

--查询约束名,并删除约束
exec sp_helpconstraint 'da111_bak2'
alter table da111_bak2
drop
constraint pk_da111_bak2
--复制行
INSERT  da111_bak2
SELECT *
FROM da111_bak2
WHERE (scodel = '03-ne-076')
/*设置影响的行数,此处复制了一次,只设置1,若是复制了屡次共有n行重复,想最后只保留一行不被影响,则设置为n-1*/
SET ROWCOUNT 1
--更新其中的1行,将ID值更改。
update da111_bak2
set id='14824553714603914625651755433750' --设置一个不一样的值
WHERE (scodel = '03-ne-076')
--还原设置S
SET ROWCOUNT 0
--恢复主键约束
alter table da111_bak2
add
constraint pk_da111_bak2
primary key (id)

 参考:http://blog.163.com/m13864039250_1/blog/static/21386524820133155536227/

http://blog.sina.com.cn/s/blog_415b73d101000838.html

相关文章
相关标签/搜索