当我在SQL Server中创建一个表并保存它时,如果我尝试编辑表设计,比如将列类型从int更改为real,我会得到这个错误:

不允许保存更改。您所做的更改要求删除并重新创建下面的表。您对无法重新创建的表进行了更改,或者启用了防止保存需要重新创建表的更改的选项。

为什么我要重新创建表格?我只是想把一个数据类型从smallint改为real。

桌子是空的,我直到现在才用过。


当前回答

这可以在Microsoft SQL Server中轻松更改。

打开Microsoft SQL Server Management Studio 2008 点击工具菜单 点击选项 选择设计师 取消勾选“防止保存需要重新创建表的更改” 单击OK

其他回答

实际上,您被SSMS阻止,而不是SQL Server。

解决方案是更改SSMS的设置或使用SQL查询。

使用SQL查询,您可以自由地进行更新。 例如,你想在一个表中添加一个新列,你可以这样做:

ALTER TABLE Customers ADD Email varchar(255) NOT NULL DEFAULT 'OK'

其他选项是更改SSMS设置。请参考其他答案,因为许多人已经解释了它。

如果在这样的列表中看不到“防止保存需要重新创建表的更改” 图像

您需要启用变更跟踪。

右键单击数据库,然后单击属性 单击更改跟踪并启用它 再次打开工具->选项->设计器,然后取消勾选。

1)打开顶部的工具。 2)从Picklist中选择选项。 3)现在弹出窗口,你可以从左边的菜单列表中选择设计师选项。 4)现在防止保存更改,需要重新创建表。现在单击OK。

如果你正在使用SSMS:

进入“工具>>选项>>设计器”菜单,取消勾选“防止保存需要重新创建表的更改”

以防这里有人也没有注意到(比如我):

对于Microsoft SQL Server 2012,在选项对话框中,有一个偷偷摸摸的小复选框,显然隐藏了所有其他设置。虽然我不得不说,我一直都很想念那个小怪物!!

在那之后,你可以继续步骤,设计,取消勾选防止保存等等等等…