不能删除列 - MS SQL

问题描述

我刚刚创建了一个新表,我想删除其中的“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)
)

现在您至少会在错误消息中获得更好的信息