我有SQL Server数据库,我刚刚意识到,我可以改变其中一列的类型从int到bool。

我怎样才能做到这一点而不丢失已经输入到表中的数据呢?


当前回答

使用检查类型更改列数据类型:

IF EXISTS(
       SELECT 1
       FROM   sys.columns
       WHERE  NAME = 'YourColumnName'
              AND [object_id] = OBJECT_ID('dbo.YourTable')
              AND TYPE_NAME(system_type_id) = 'int'
   )
    ALTER TABLE dbo.YourTable ALTER COLUMN YourColumnName BIT

其他回答

您可以使用以下命令轻松完成此操作。任何0的值都将被转换为0 (BIT = false),任何其他值都将被转换为1 (BIT = true)。

ALTER TABLE dbo.YourTable
   ALTER COLUMN YourColumnName BIT

另一种选择是创建一个BIT类型的新列,从旧列填充它,完成之后,删除旧列并将新列重命名为旧名称。这样,如果在转换过程中出现了问题,您可以随时返回,因为您仍然拥有所有数据。

使用检查类型更改列数据类型:

IF EXISTS(
       SELECT 1
       FROM   sys.columns
       WHERE  NAME = 'YourColumnName'
              AND [object_id] = OBJECT_ID('dbo.YourTable')
              AND TYPE_NAME(system_type_id) = 'int'
   )
    ALTER TABLE dbo.YourTable ALTER COLUMN YourColumnName BIT

我可以修改表字段的数据类型,与以下查询:

ALTER TABLE table_name
MODIFY column_name datatype;

为什么你认为你会丢失数据?只需进入Management Studio并更改数据类型。如果现有值可以转换为bool (bit),它就会这样做。换句话说,如果在原始字段中“1”映射为真,而“0”映射为假,那么就没问题。

在精简版中,将自动获取datetime数据类型的大小,即(8),因此不需要设置字段的大小并为此操作生成错误…