更改表然后更新

Vla*_*lad 6 sql t-sql database

我怎样才能在transact sql中实现这一点.

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

这是一个示例代码

 ALTER TABLE my_table ADD my_new_column bit NULL;

 UPDATE my_table SET my_new_column = 0;
Run Code Online (Sandbox Code Playgroud)

我知道我正在写作,而列仍然不存在,所以这就是为什么这两行不起作用.但是如何在一个脚本中实现这一点,即使用一些延迟或如何确保创建列然后向其写入数据?

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

谢谢

Mar*_*ith 14

您可以添加新列并通过添加默认值并使用该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
Run Code Online (Sandbox Code Playgroud)

  • 您可以以相同的方式添加多个列和默认约束.除此之外,通常最好在DML的不同批处理中执行DDL以避免解析问题(通过在语句之间添加`GO`或使用`EXEC`取决于您需要执行此操作的上下文) (2认同)