在不动用sp_configure的情况下,如何 =》去掉列的自增长,并保留原数据-阿里云开发者社区

开发者社区> 数据库> 正文
登录阅读全文

在不动用sp_configure的情况下,如何 =》去掉列的自增长,并保留原数据

简介:

 异常处理汇总-数据库系列  http://www.cnblogs.com/dunitian/p/4522990.html

后期博客首发:http://dnt.dkill.net/Article/Detail/317

应用场景:权限不够(只是某个用户,权限很低,不能使用sp_configure

执行

附录:

1
2
3
4
update BackupShopMenu set TempId=MId
alter table BackupShopMenu drop column MId
exec sp_rename 'BackupShopMenu.TempId''MId''column'
alter table BackupShopMenu alter column MId int not null --如果你的字段是可以为null就不需要这段了

网上参考:

如何用sql语句去掉列的自增长(identity) 

**无法通过alter把现有自增字段改为非自增 
比如alter   table   a   alter   id   int,自增属性不会去掉 
通过修改系统表可以做到(此法可能有不可预知的结果,慎之...) 
sp_configure   'allow   updates ',   1 
GO 
reconfigure   with   override 
GO 
update   syscolumns   set   colstat   =   colstat   &   0x0000   
where     id=object_id( '表名 ')   and   name= '字段名 ' 
GO 
sp_configure   'allow   updates ',   0 

--------------------------------------------- 
--折中的办法 
alter   table   a   add   xxx   int 
update   a   set   xxx=id 
alter   table   a   drop   column   id 
exec   sp_rename   'xxx ',   'id ',   'column ' 
---------------------------------------------

 

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

分享: