我有一个包含许多表的 SQL Server 2008 数据库。我一直在使用现在蹩脚的 datetime
数据类型并希望使用新的更好的 datetime2
.在我有日期时间字段的大多数地方,对应的列名是 Timestamp
.是否有任何地方可以从 datatime
进行批量更改?至 datetime2
?
最佳答案
在 Management Studio 中运行它,复制结果并粘贴到新的查询窗口中:
select 'ALTER TABLE ' + OBJECT_NAME(o.object_id) +
' ALTER COLUMN ' + c.name + ' DATETIME2 ' +
CASE WHEN c.is_nullable = 0 THEN 'NOT NULL' ELSE 'NULL' END
from sys.objects o
inner join sys.columns c on o.object_id = c.object_id
inner join sys.types t on c.system_type_id = t.system_type_id
where o.type='U'
and c.name = 'Timestamp'
and t.name = 'datetime'
order by OBJECT_NAME(o.object_id)
关于SQL Server 2008 : Bulk Datatype Change,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3644660/