一 SQL删除列的语句是:
alter table tableName drop column columnName --(其中,tableName为表名,columnName为列名)
但是,如果某列有约束时,不能直接删除,需要先删除约束,再删除列。如果某个列是外键,在不知道外键约束名称的情况下,那么首先是查找外键约束名称,根据名称删除约束,然后再删除列。
二 如何查找外键约束
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 sys s c on a.constid=c.id
where a.id= _id(@TableName)
and b.name=@ColumnName
上述代码在使用的时候需要给@TableName赋值实际的表名,@ColumnName为实际的列名。
三 知道了约束名就可以删除约束了
ALTER TABLE @TableName DROP CONSTRAINT @CONSTRAINT_NAME
四 将上面的代码合并,于是有下面的代码
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 sys s c on a.constid=c.id
where a.id= _id(@TableName)
and b.name=@ColumnName
DECLARE @Sql NVARCHAR(512) = N'ALTER TABLE ' + @TableName + ' DROP CONSTRAINT ' + @CONSTRAINT_Key
EXECUTE sys.sp_executesql @Sql
继续阅读与本文标签相同的文章
下一篇 :
使用智能语音交互识别视频中的音频
-
Java并发系列(4)java关键字-synchronized
2026-05-18栏目: 教程
-
汇编(六)栈段、第一个汇编程序
2026-05-18栏目: 教程
-
目前Web前端就业前景如何 前端应用于哪些领域
2026-05-18栏目: 教程
-
kubernetes Service:让客户端发现pod并与之通信
2026-05-18栏目: 教程
-
新版本上线前期,产品经理要做那几点事?
2026-05-18栏目: 教程
