我怎样才能在transact
sql中实现这一点.
我想在现有表中添加新列,然后使用一些值更新它.是否可以在一个sql脚本中执行它,或者我应该使用单独的脚本?
这是一个示例代码
ALTER TABLE my_table ADD my_new_column bit NULL;
UPDATE my_table SET my_new_column = 0;
我知道我正在写作,而列仍然不存在,所以这就是为什么这两行不起作用.但是如何在一个脚本中实现这一点,即使用一些延迟或如何确保创建列然后向其写入数据?
我使用IF EXISTS从表中选择,但它不起作用.
谢谢
您可以
添加新列并通过
添加默认值并使用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