当我在SQL Server中创建一个表并保存它时,如果我尝试编辑表设计,比如将列类型从int更改为real,我会得到这个错误:
不允许保存更改。您所做的更改要求删除并重新创建下面的表。您对无法重新创建的表进行了更改,或者启用了防止保存需要重新创建表的更改的选项。
为什么我要重新创建表格?我只是想把一个数据类型从smallint改为real。
桌子是空的,我直到现在才用过。
当我在SQL Server中创建一个表并保存它时,如果我尝试编辑表设计,比如将列类型从int更改为real,我会得到这个错误:
不允许保存更改。您所做的更改要求删除并重新创建下面的表。您对无法重新创建的表进行了更改,或者启用了防止保存需要重新创建表的更改的选项。
为什么我要重新创建表格?我只是想把一个数据类型从smallint改为real。
桌子是空的,我直到现在才用过。
当前回答
1)打开顶部的工具。 2)从Picklist中选择选项。 3)现在弹出窗口,你可以从左边的菜单列表中选择设计师选项。 4)现在防止保存更改,需要重新创建表。现在单击OK。
其他回答
从此链接复制 “…重要事项:我们强烈建议您不要通过关闭“防止保存需要重新创建表的更改”选项来解决此问题。有关关闭此选项的风险的更多信息,请参阅“更多信息”部分。”
“…要解决此问题,请使用Transact-SQL语句对表的元数据结构进行更改。有关更多信息,请参阅SQL Server联机书籍中的以下主题
例如,要更改MyTable中datetime类型的MyDate列以接受NULL值,您可以使用:
修改表MyDate7为空
防止保存需要重新创建表的更改 五声急促的咔哒声 工具 选项 设计师 防止保存需要重新创建表的更改 好的。 保存后,重复上述步骤,重新勾选复选框。这可以防止意外数据丢失。
进一步的解释
默认情况下,SQL Server Management Studio阻止表的删除,因为当一个表被删除时,它的数据内容就丢失了 在表设计视图中更改列的数据类型时,在保存更改时,数据库将在内部删除表,然后重新创建一个新表。
*您的具体情况不会造成任何后果,因为您的表是空的。我提供这个解释完全是为了提高您对这个过程的理解。
实际上,您被SSMS阻止,而不是SQL Server。
解决方案是更改SSMS的设置或使用SQL查询。
使用SQL查询,您可以自由地进行更新。 例如,你想在一个表中添加一个新列,你可以这样做:
ALTER TABLE Customers ADD Email varchar(255) NOT NULL DEFAULT 'OK'
其他选项是更改SSMS设置。请参考其他答案,因为许多人已经解释了它。
从“工具”菜单中,单击“选项”,从侧菜单中选择“设计器”,并取消勾选防止可能导致重新创建表的更改。然后保存更改
取消选中“工具►选项►设计器”页签中的“防止保存需要重新创建表的更改”框。
SQL Server 2012示例: