zoukankan      html  css  js  c++  java
  • SQL 删除外键列

    一 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) = N'ALTER TABLE ' + @TableName + ' DROP CONSTRAINT ' + @CONSTRAINT_Key
    EXECUTE sys.sp_executesql @Sql

     

  • 相关阅读:
    数学形态学——腐蚀、膨胀、开、闭、细化
    VS2010中 报错:error C2146、error C4430 原因一:缺少CvvImage类
    帧同步和状态同步
    HTML5触摸事件演化tap事件
    screenX clientX pageX的区别
    phaser的小游戏的onInputDown问题
    phaser入手
    pixi.js 微信小游戏 入手
    正则表达式
    剖析Vue原理&实现双向绑定MVVM-2
  • 原文地址:https://www.cnblogs.com/godbell/p/9688844.html
Copyright © 2011-2022 走看看