我正在努力将SQL Server中的DateTime字段迁移到DateTimeOffset的时间已到。
想知道SQL Server中是否有任何可以帮助我的自动化工具,所以我不需要编写一堆alter table语句?
答案 0 :(得分:4)
SQL Server本身没有这样的工具,但是有第三方工具,它们包含数据库的管理任务并为您生成更改脚本。
如果没有第三方工具,您可以编写一个脚本,为您生成更改脚本。
下面是一个示例脚本,它查找datatime
类型的所有列并生成脚本以将其更改为DateTimeOffset
数据类型。
select
OBJECT_NAME (a.object_id) as Table_Name
,a.name as Colimn_Name
,b.name as Old_Datatype
,'ALTER TABLE ' + OBJECT_NAME (a.object_id) + ' ALTER COLUMN ' + a.name + ' DATETIMEOFFSET ' +
CASE a.is_nullable
when 1 then ' NULL '
else ' NOT NULL '
END
from sys.columns a
join sys.types b on a.user_type_id = b.user_type_id
join sys.tables c on a.object_id = c.object_id
where b.name = 'datetime'
and c.type = 'U'
此外,您可以使用未记录的sp_msForEachTable
来为数据库中的每个表执行代码。
答案 1 :(得分:1)
我有类似的问题。
以下是我更新列的方法。我按照我在网上找到的一个例子将DateTime列转换为DateTimeOffset。
例如,对于NorthWind数据库,您可以执行以下操作。首先执行创建转换函数
CREATE FUNCTION fn_DSTOffset( @date1 DATETIMEOFFSET )
RETURNS INT
AS
BEGIN
RETURN
CASE WHEN ( ( @date1 > '2009-3-29 2:00' AND @date1 <= '2009-10-25 2:00' )
OR ( @date1 > '2010-3-28 2:00' AND @date1 <= '2010-10-31 2:00' )
OR ( @date1 > '2011-3-27 2:00' AND @date1 <= '2011-10-30 2:00' ) )
THEN 60 -- offset in minutes
ELSE 0
END
END
GO
尝试使用此函数更改列 - 下面的示例显示了如何为Bi
执行此操作