基础SQL Server 操作问题——对象‘主键’依赖于列‘ID’/标识列‘ID’的数据类型必须是int,bigint,smallint等

修改主键属性

alter table Categories

alter column CategoryID  CHAR(20) NOt NULL

-------Categories是表名, CategoryID是主键字段名, Char(20) NOT NULL 是要修改的类型

问题:

对象'PK_Categories' 依赖于 列'CategoryID'。

消息 4922,级别 16,状态 9,第 3 行

由于一个或多个对象访问此列,ALTER TABLE ALTER COLUMN CategoryID 失败

解决办法:

删除主键设置:可以用SQL语句,可以手动改表格设置

alter table Categories ------Categories是表名

drop constraint PK_Categories -------PK_Categories是主键名

再次执行修改属性命令后报错:

解决办法:

1、可以考虑修改系统表的属性值:

update syscolumns set colstat = 0 where id = object_id('Categories') and colstat = 1

但是需要获取到科修改系统表权限

2、还是直接手动修改标识列不自增即可

 

评论 16
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

邢美玲

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值