微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

sql – 更改表然后更新

我怎样才能在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

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐