新聞中心
SQL Server刪除操作是最常用的操作之一,下面就為您介紹如何在有默認(rèn)約束情況下實(shí)現(xiàn)SQL Server刪除數(shù)據(jù),希望對您能有所啟迪。

創(chuàng)新互聯(lián)建站專注于企業(yè)營銷型網(wǎng)站、網(wǎng)站重做改版、華容網(wǎng)站定制設(shè)計(jì)、自適應(yīng)品牌網(wǎng)站建設(shè)、H5建站、商城系統(tǒng)網(wǎng)站開發(fā)、集團(tuán)公司官網(wǎng)建設(shè)、外貿(mào)網(wǎng)站制作、高端網(wǎng)站制作、響應(yīng)式網(wǎng)頁設(shè)計(jì)等建站業(yè)務(wù),價(jià)格優(yōu)惠性價(jià)比高,為華容等各大城市提供網(wǎng)站開發(fā)制作服務(wù)。
在SQL Server 中,如果給表的一個(gè)字段設(shè)置了默認(rèn)值,就會在系統(tǒng)表sysobjects中生成一個(gè)默認(rèn)約束。
如果想刪除這個(gè)設(shè)置了默認(rèn)值的字段(假設(shè)此字段名column1),執(zhí)行“ALTER TABLE table1 DROP COLUMN column1”時(shí)就會報(bào)錯(cuò):
The object .DF__xxxxxxxxxxx. is dependent on column .column1..
ALTER TABLE DROP COLUMN column1failed because one or more objects access this column.
所以SQL Server刪除此字段時(shí)需要先將系統(tǒng)表中的對應(yīng)默認(rèn)約束刪除, 可以使用下面的腳本進(jìn)行刪除:
-- this script drops the default constraint which is generated by the setting of default value.
-- SQL Server刪除約束
- DECLARE @tablename VARCHAR(100), @columnname VARCHAR(100), @tab VARCHAR(100)
- SET @tablename='表名'
- SET @columnname='字段名'
- 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) AND
- name = @columnname)
- select @cmd='alter table '+ @tablename+ ' drop constraint '+ @defname
- if @cmd is null print 'No default constraint to drop'
- exec (@cmd)
-- 刪除約束結(jié)束
在刪除對應(yīng)的默認(rèn)約束后,執(zhí)行:
- ALTER TABLE table1 DROP COLUMN column1
即可刪除字段。
【編輯推薦】
六種SQL Server刪除重復(fù)行的方法
SQL Server創(chuàng)建數(shù)據(jù)庫的命令
SQL server服務(wù)器版的安裝方法
SQL SERVER連接失敗的解決方案
帶您了解SQL Server游標(biāo)
分享題目:有默認(rèn)約束情況下的SQLServer刪除方法
當(dāng)前地址:http://www.dlmjj.cn/article/djsichh.html


咨詢
建站咨詢
