适用于: SQL Server 2016 (13.x) 及更高版本
Azure SQL 数据库
Azure SQL 托管实例
Azure Synapse Analytics
分析平台系统(PDW)
Microsoft Fabric 预览版中的 SQL 数据库
本文介绍如何使用 SQL Server Management Studio (SSMS) 或 Transact-SQL 删除 SQL Server 中的表列。
Caution
删除表中的某一列后,该列及其包含的所有数据都将删除。
Limitations
不能删除具有 CHECK 约束的列。 必须首先删除该约束。
不能删除具有 PRIMARY KEY 或 FOREIGN KEY 约束或者其他依赖项的列,但在 SSMS 中使用表设计器时除外。 在使用 SSMS 的对象资源管理器或 Transact-SQL 时,必须首先删除该列上的所有依赖关系。
Permissions
要求对表具有 ALTER 权限。
使用 SQL Server Management Studio 删除列
可以使用对象资源管理器或表设计器来删除 SSMS 中的列。
使用对象资源管理器删除列
以下步骤说明如何在 SSMS 中使用对象资源管理器删除列:
连接到数据库引擎实例。
在“对象资源管理器”中,找到要从其中删除列的表,然后展开表,显示列名称。
右键单击要删除的列,然后选择“删除”。
在“删除对象”对话框中,选择“确定”。
如果该列包含约束或其他依赖关系,“删除对象”对话框中会显示错误消息。 通过删除引用的约束解决该错误。
使用表设计器删除列
以下步骤说明如何在 SSMS 中使用表设计器删除列:
在“对象资源管理器”中,右键单击要从其中删除列的表,然后选择“设计”。
右键单击要删除的列,然后从快捷菜单上选择“删除列”。
如果该列参与了关系(
FOREIGN KEY或PRIMARY KEY),则将显示一条消息,提示确认删除所选列及其关系。 Choose Yes.
使用 Transact-SQL 删除列
可以在 SSMS、Azure Data Studio 或命令行工具(例如 sqlcmd 实用程序)中使用 Transact-SQL 删除列。
下面的示例展示了如何从表 column_b 中删除列 dbo.doc_exb。 表和列必须已经存在。
ALTER TABLE dbo.doc_exb DROP COLUMN column_b;
GO
如果该列包含约束或其他依赖项,则会返回一条错误消息。 通过删除引用的约束解决该错误。
有关更多示例,请参阅 ALTER TABLE。