使用 SQL Server 2008、Visual Studio 2005、带有 SP2 的 .net 2.0(支持新的 SQL Server 2008 数据类型)。
我正在尝试编写一个 SQLCLR 函数,该函数将 DateTime2 作为输入并返回另一个 DateTime2。例如:
using System;
using System.Data.SqlTypes;
using Microsoft.SqlServer.Server;
namespace MyCompany.SQLCLR
{
public class DateTimeHelpCLR
{
[SqlFunction(DataAccess = DataAccessKind.None)]
public static SqlDateTime UTCToLocalDT(SqlDateTime val)
{
if (val.IsNull)
return SqlDateTime.Null;
TimeZone tz = System.TimeZone.CurrentTimeZone;
DateTime res = tz.ToLocalTime(val.Value);
return new SqlDateTime(res);
}
}
}
现在,上面的编译很好。我希望这些 SqlDateTimes 映射到 SQL Server 的 DateTime2,所以我尝试运行这个 T-SQL:
CREATE function hubg.f_UTCToLocalDT
(
@dt DATETIME2
)
returns DATETIME2
AS
EXTERNAL NAME [SQLCLR].[MyCompany.SQLCLR.DateTimeHelpCLR].UTCToLocalDT
GO
这给出了以下错误:
消息 6551,级别 16,状态 2,过程 f_UTCToLocalDT,第 1 行“f_UTCToLocalDT”的 CREATE FUNCTION 失败,因为返回值的 T-SQL 和 CLR 类型不匹配。
使用 DATETIME(而不是 DATETIME2)可以正常工作。但我宁愿使用 DATETIME2 来支持提高的精度。我做错了什么,还是 SQLCLR 不(完全)支持 DateTime2 ?