Sealyu

          --- 博客已遷移至: http://www.sealyu.com/blog

            BlogJava :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::
            618 隨筆 :: 87 文章 :: 225 評論 :: 0 Trackbacks
          <2008年4月>
          303112345
          6789101112
          13141516171819
          20212223242526
          27282930123
          45678910

          常用鏈接

          留言簿(14)

          隨筆分類

          隨筆檔案

          友情鏈接

          搜索

          積分與排名

          最新評論

          閱讀排行榜

          評論排行榜

          作者: sealyu   日期:2008-04-17
          在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) AND
          name = @columnname)

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

          在刪除對應的默認約束后,執行:
          ALTER TABLE table1 DROP COLUMN column1
          即可刪除字段。
          posted on 2008-04-17 14:31 seal 閱讀(1998) 評論(0)  編輯  收藏 所屬分類: 數據庫
          主站蜘蛛池模板: 阳朔县| 莆田市| 襄汾县| 阳西县| 呈贡县| 乐陵市| 石柱| 河北区| 株洲市| 磐石市| 武穴市| 康定县| 祥云县| 乌什县| 芮城县| 孙吴县| 安图县| 乐清市| 高要市| 鲁山县| 衡阳县| 凤凰县| 商丘市| 兴化市| 扎囊县| 涡阳县| 千阳县| 延寿县| 英超| 洛宁县| 宾川县| 时尚| 洛扎县| 邮箱| 潍坊市| 华蓥市| 拉萨市| 且末县| 交城县| 通渭县| 井陉县|