我有SQL Server数据库,我刚刚意识到,我可以改变其中一列的类型从int到bool。
我怎样才能做到这一点而不丢失已经输入到表中的数据呢?
我有SQL Server数据库,我刚刚意识到,我可以改变其中一列的类型从int到bool。
我怎样才能做到这一点而不丢失已经输入到表中的数据呢?
当前回答
如果你使用T-SQL(MSSQL);你应该试试这个脚本:
ALTER TABLE [Employee] ALTER COLUMN [Salary] NUMERIC(22,5)
如果你使用MySQL;你应该试试这个脚本:
ALTER TABLE [Employee] MODIFY COLUMN [Salary] NUMERIC(22,5)
如果你使用甲骨文;你应该试试这个脚本:
ALTER TABLE [Employee] MODIFY [Salary] NUMERIC(22,5)
其他回答
我可以修改表字段的数据类型,与以下查询:
ALTER TABLE table_name
MODIFY column_name datatype;
如果你使用T-SQL(MSSQL);你应该试试这个脚本:
ALTER TABLE [Employee] ALTER COLUMN [Salary] NUMERIC(22,5)
如果你使用MySQL;你应该试试这个脚本:
ALTER TABLE [Employee] MODIFY COLUMN [Salary] NUMERIC(22,5)
如果你使用甲骨文;你应该试试这个脚本:
ALTER TABLE [Employee] MODIFY [Salary] NUMERIC(22,5)
使用检查类型更改列数据类型:
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
为什么你认为你会丢失数据?只需进入Management Studio并更改数据类型。如果现有值可以转换为bool (bit),它就会这样做。换句话说,如果在原始字段中“1”映射为真,而“0”映射为假,那么就没问题。
替换数据类型而不丢失数据
alter table tablename modify columnn newdatatype(size);