sql server中預設約束的通用sql指令碼的刪除方法
在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/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- Sql server 檢視錶引用、依賴項,刪除表及約束 指令碼SQLServer指令碼
- SQL Server唯一約束的使用SQLServer
- sql server編寫archive通用模板指令碼實現自動分批刪除資料SQLServerHive指令碼
- 刪除SQL Server日誌的具體方法SQLServer
- SQL Server中刪除重複資料的幾個方法SQLServer
- SQL SERVER中找出拙劣的約束,索引,外來鍵SQLServer索引
- SQL Server語句刪除帶有預設值的欄位SQLServer
- Sql Server系列:鍵和約束SQLServer
- SQL Server 資料表程式碼建立約束SQLServer
- 講解刪除SQL Server日誌的具體方法SQLServer
- SQL約束SQL
- SQL Server中快速生成大量記錄的SQL指令碼SQLServer指令碼
- 生成指令碼,得到所有表的外來鍵約束,然後刪除並重建這些約束指令碼
- SQL Server約束和DML觸發器的比較SQLServer觸發器
- SQL2000中預設sa帳號改名和刪除的最安全方法SQL
- sql server 中刪除內容重複的某條記錄SQLServer
- SQL Server停止指令碼SQLServer指令碼
- 【SQL】15 SQL 約束(Constraints)、NOT NULL 約束、UNIQUE 約束、PRIMARY KEY 約束、FOREIGN KEY 約束、CHECK 約束、DEFAULT約束SQLAINull
- SQL Server映象自動生成指令碼方法SQLServer指令碼
- SQL Server 觸發器的修改與刪除SQLServer觸發器
- 詳細講解刪除SQL Server日誌的具體方法SQLServer
- 新增/刪除約束(Oracle)Oracle
- 記一次SQL Server刪除SQL調優SQLServer
- SQL Server實戰三:資料庫表完整性約束及索引、檢視的建立、編輯與刪除SQLServer資料庫索引
- sql: 查詢約束SQL
- SQL Server正確刪除Windows認證使用者的方法教程SQLServerWindows
- 批量刪除MSSQL 中主外來鍵約束SQL
- SQL Server中使用Check約束達到提升效能SQLServer
- SQL Server啟動指令碼SQLServer指令碼
- SQL SERVER執行指令碼SQLServer指令碼
- SQL SERVER巡檢指令碼SQLServer指令碼
- 刪除SQL隱碼攻擊的程式碼SQL
- 在SQL Server中快速刪除重複記錄(轉)SQLServer
- [備忘]刪除SQL Server中無登入名的使用者SQLServer
- SQL Server預設1433埠修改方法SQLServer
- SQL SERVER檢視列的預設值SQLServer
- SQL Server2008建立約束圖解SQLServer圖解
- SQL SERVER 規則的建立、繫結、解綁、刪除SQLServer