sql server中默认约束的通用sql脚本的删除方法

转帖|其它|编辑:郝浩|2009-02-05 15:15:45.000|阅读 782 次

概述:sql server中默认约束的通用sql脚本的删除方法

# 界面/图表报表/文档/IDE等千款热门软控件火热销售中 >>

在SQL Server 中,如果给表的一个字段设置了默认值,就会在系统表sysobjects中生成一个默认约束。
如果想删除这个设置了默认值的字段(假设此字段名column1),执行“ALTER TABLE table1 DROP COLUMN column1”时就会报错:

以下为引用的内容:

The object 'DF__xxxxxxxxxxx' is dependent on column 'column1'.
ALTER TABLE DROP COLUMN column1failed because one or more objects access this column.

所以在删除此字段时需要先将系统表中的对应默认约束删除, 可以使用下面的脚本进行删除:

以下为引用的内容:

-- this script drops the default constraint which is generated by the setting of default value.
DECLARE @tablename VARCHAR(100), @columnname VARCHAR(100), @tab VARCHAR(100)

SET @tablename='CountryGroupEmailAndWaitAux'

SET @columnname='actionOfHasNoValidEmail'

declare @defname varchar(100)

declare @cmd varchar(100)

select @defname = name FROM sysobjects so JOIN sysconstraints sc

ON so.id = sc.constid

WHERE object_name(so.parent_obj) = @tablename AND so.xtype = 'D'AND sc.colid =(SELECT colid FROM syscolumns WHERE id = object_id(@tablename) ANDname = @columnname)

select @cmd='alter table '+ @tablename+ ' drop constraint '+ @defnameif @cmd is null print 'No default constraint to drop'exec (@cmd)

在删除对应的默认约束后,执行:

ALTER TABLE table1 DROP COLUMN column1

即可删除字段。


标签:

本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@evget.com

文章转载自:BlogJava

为你推荐

  • 推荐视频
  • 推荐活动
  • 推荐产品
  • 推荐文章
  • 慧都慧问
扫码咨询


添加微信 立即咨询

电话咨询

客服热线
023-68661681

TOP