使用 SQL Server 2008、Visual Studio 2005、.net 2.0 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
这会产生以下错误:
消息 6551,级别 16,状态 2,程序
f_UTCToLocalDT,第 1 行创建函数
对于“f_UTCToLocalDT”失败,因为
返回值的 T-SQL 和 CLR 类型
不匹配。
使用 DATETIME (而不是 DATETIME2)效果很好。但我宁愿使用 DATETIME2 来支持提高的精度。我做错了什么,或者 SQLCLR 不(完全)支持 DateTime2 ?
您需要更改函数方法签名中的日期时间类型。 SQLDateTime 映射到数据库上的日期时间。
System.DateTime 更精确can映射到 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
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)