首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Alter table然后更新

Alter table然后更新
EN

Stack Overflow用户
提问于 2012-09-18 15:48:58
回答 1查看 5K关注 0票数 7

如何在transact sql中实现这一点。

我想将新列添加到现有表中,然后用一些值更新它。是否可以在一个sql脚本中完成,或者我应该使用单独的脚本?

以下是示例代码

代码语言:javascript
复制
 ALTER TABLE my_table ADD my_new_column bit NULL;

 UPDATE my_table SET my_new_column = 0;

我知道我正在写文章,而这个专栏还不存在,所以这就是为什么这两行不能工作的原因。但是,如何在一个脚本中实现这一点,即使用一些延迟,或者如何确保列被创建,然后向其中写入数据?

我使用IF EXISTS和select从表中选择,但它不起作用。

谢谢

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2012-09-18 15:51:44

通过添加一个默认值并使用WITH VALUES子句,您可以同时添加新列并填充它。然后,如果不再需要,可以在末尾删除默认值。这种方法可以用于多个列,如下所示。

代码语言:javascript
复制
ALTER TABLE [myTable]
ADD [my_new_column] [bit] NULL CONSTRAINT DF_TMP DEFAULT 0 ,
    [my_new_column2] [bit] NULL CONSTRAINT DF_TMP2 DEFAULT 1 WITH VALUES;

ALTER TABLE [myTable] DROP DF_TMP, DF_TMP2
票数 16
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/12472571

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档