问题描述
我刚刚创建了一个新表,我想删除其中的“person
”列,但出现错误 -
CREATE TABLE new_info(
info_id INT IDENTITY (1,1) PRIMARY KEY,title VARCHAR(500) NOT NULL,person VARCHAR(50) NOT NULL UNIQUE
)
在这之后 -
ALTER TABLE new_info
DROP COLUMN person;
我收到此错误 -
Msg 5074,Level 16,State 1,Line 1
The object 'UQ__@R_656_4045@__DC4560C2776204D1' is dependent on column 'person'.
Msg 4922,State 9,Line 1
ALTER TABLE DROP COLUMN person Failed because one or more objects access this column.
知道为什么,或者是什么原因造成的吗?
解决方法
先删除唯一约束,然后才能删除列 这就是为什么总是最好创建命名约束
ALTER TABLE new_info DROP CONSTRAINT UQ__informat__DC4560C2776204D1
然后您可以删除您的列。 正如 Martin 所评论的,您也可以在一个声明中做到这一点
ALTER TABLE new_info DROP UQ__informat__DC4560C2776204D1,COLUMN person
最好创建这样的表
CREATE TABLE new_info(
info_id INT IDENTITY(1,1),title VARCHAR(500) NOT NULL,person VARCHAR(50) NOT NULL,constraint PK_new_info_InfoID primary key (info_id),constraint IX_new_info_person UNIQUE (person)
)
现在您至少会在错误消息中获得更好的信息