一 SQL删除列的语句是: sql
alter table tableName drop column columnName --(其中,tableName为表名,columnName为列名)
可是,若是某列有约束时,不能直接删除,须要先删除约束,再删除列。若是某个列是外键,在不知道外键约束名称的状况下,那么首先是查找外键约束名称,根据名称删除约束,而后再删除列。spa
二 如何查找外键约束code
DECLARE @TableName NVARCHAR(64) = ''
DECLARE @ColumnName NVARCHAR(32) = ''SELECT c.name FROM sysconstraints a inner join syscolumns b on a.colid=b.colid inner join sysobjects c on a.constid=c.id where a.id=object_id(@TableName) and b.name=@ColumnName
上述代码在使用的时候须要给@TableName赋值实际的表名,@ColumnName为实际的列名。blog
三 知道了约束名就能够删除约束了it
ALTER TABLE @TableName DROP CONSTRAINT @CONSTRAINT_NAME
四 将上面的代码合并,因而有下面的代码table
DECLARE @TableName NVARCHAR(64) = ''
DECLARE @ColumnName NVARCHAR(32) = ''
DECLARE @CONSTRAINT_Key SYSNAME SELECT @CONSTRAINT_Key = c.name FROM sysconstraints a inner join syscolumns b on a.colid=b.colid inner join sysobjects c on a.constid=c.id where a.id=object_id(@TableName) and b.name=@ColumnName
DECLARE @Sql NVARCHAR(512) = N'ALTER TABLE ' + @TableName + ' DROP CONSTRAINT ' + @CONSTRAINT_Key
EXECUTE sys.sp_executesql @Sql