使用sql Server 2008,Visual Studio 2005,.net 2.0 with SP2(支持新的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
这会出现以下错误:
Msg 6551,Level 16,State 2,Procedure
f_UTCToLocalDT,Line 1 CREATE FUNCTION
for “f_UTCToLocalDT” Failed because
T-sql and CLR types for return value
do not match.
使用DATETIME(而不是DATETIME2)工作正常.但我宁愿使用DATETIME2来支持提高的精度.我做错了什么,或者sqlCLR没有(完全)支持DateTime2?
解决方法
您需要在函数方法的签名中更改DateTime类型. sqlDateTime映射到数据库上的DateTime.
System.DateTime更精确,可以映射到DateTime2(但默认情况下,它将在部署脚本中作为DateTime删除).
[sqlFunction(DataAccess = DataAccessKind.None)] //OLD Signature public static sqlDateTime UTCToLocalDT(sqlDateTime val) public static DateTime UTCToLocalDT(DateTime val) { ... }
然后,您可以调整部署脚本以进行阅读.
CREATE FUNCTION [UTCToLocalDT] ( @dt [datetime2] ) RETURNS [datetime2] AS EXTERNAL NAME [sqlCLR].[MyCompany.sqlCLR.DateTimeHelpCLR].UTCToLocalDT GO
DECLARE @input DateTime2,@output DateTime2 SET @input = '2010-04-12 09:53:44.48123456' SET @output = YourDatabase.dbo.[UTCToLocalDT](@input) SELECT @input,@output