sql server中預設約束的通用sql指令碼的刪除方法

iSQlServer發表於2009-02-11

在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

即可刪除欄位。

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/16436858/viewspace-548722/,如需轉載,請註明出處,否則將追究法律責任。

相關文章