我的任务是获取一些在 SQL Server 2012 上正常工作的代码,以便在 SQL Server 2008 R2 上也能正常工作。我收到这个错误:
附加信息:“
当我尝试运行我的代码时,我发现这行 SQL 代码有问题
ALTER TABLE [dbo].[WorkTimeEntries]
ADD [TimeFinishedForRuntime] AS ISNULL([TimeFinished],
IIF ([TimeStarted] < SYSUTCDATETIME(), [dbo].[udf_GetCurrentDateTimeOffsetInTimeZone](DATENAME(TZOFFSET, [TimeStarted])), [TimeStarted]));
我读过,在这种情况下,当人们尝试获取约会时发生了某种错误,但我不确定我的情况出了什么问题。
没有IIF
在 SQL Server 2008R2 中。
将其替换为CASE
ALTER TABLE [dbo].[WorkTimeEntries] ADD [TimeFinishedForRuntime] AS ISNULL(
[TimeFinished],
CASE WHEN [TimeStarted] < SYSUTCDATETIME() THEN [dbo].[udf_GetCurrentDateTimeOffsetInTimeZone](DATENAME(TZOFFSET, [TimeStarted])) ELSE [TimeStarted] END);
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)