码迷,mamicode.com
首页 > 数据库 > 详细

SQL 删除外键列

时间:2018-09-22 00:50:42      阅读:264      评论:0      收藏:0      [点我收藏+]

标签:ble   size   color   nts   cut   col   如何   alt   select   

一 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 sysobjects c on a.constid=c.id
where a.id=object_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 sysobjects c on a.constid=c.id
where a.id=object_id(@TableName) 
and b.name=@ColumnName
DECLARE @Sql NVARCHAR(512) = NALTER TABLE  + @TableName +  DROP CONSTRAINT  + @CONSTRAINT_Key
EXECUTE sys.sp_executesql @Sql

 

SQL 删除外键列

标签:ble   size   color   nts   cut   col   如何   alt   select   

原文地址:https://www.cnblogs.com/godbell/p/9688844.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!