修改表字段的默认值

 修改表的默认值的方法大家都知道了,给表建立一个约束即可,如:

ALTER   TABLE   TableName   add constraint ConstraintName default ('abc') for FieldName

一般做添加修改默认值的功能时还要判断这个字段上是不是已经有了约束了。如果有约束就必须在建立约束前先删除原来的约束,否则会报出:

消息 1781,级别 16,状态 1,第 5 行
已在列上绑定了 DEFAULT。
消息 1750,级别 16,状态 0,第 5 行
无法创建约束。请参阅前面的错误消息。

这是由于在要建立约束的列上已经有了一个约束的缘故,所以要先判断,如果已有约束就要删除它:

if exists(select   *  from   sysobjects   where   name='ConstraintName')
begin
ALTER TABLE bbb DROP CONSTRAINT ConstraintName
end

如果这个'abc'默认值是一个变量的话就只能用动态语句了。

Exec('ALTER TABLE TableName add constraint ConstraintName default (''' + @TableName + ''') for FieldName')--注意,这里@TableName变量是varchar类型,外面是3个单引号。

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值