7

如何在事务 sql 中实现这一点。

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

这是一个示例代码

 ALTER TABLE my_table ADD my_new_column bit NULL;

 UPDATE my_table SET my_new_column = 0;

我知道我正在写作,而该专栏仍然不存在,所以这就是这两行不起作用的原因。但是如何在一个脚本中实现这一点,即使用一些延迟或如何确保创建列然后将数据写入它?

我将 IF EXISTS 与从表中选择一起使用,但它不起作用。

谢谢

4

1 回答 1

16

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

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
于 2012-09-18T07:51:43.650 回答