gpt4 book ai didi

c# - SQLCLR 和 DateTime2

转载 作者:太空狗 更新时间:2023-10-29 21:15:28 27 4
gpt4 key购买 nike

使用 SQL Server 2008、Visual Studio 2005、.net 2.0 SP2(支持新的 SQL Server 2008 数据类型)。

我正在尝试编写一个将 DateTime2 作为输入并返回另一个 DateTime2 的 SQLCLR 函数。例如:

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

关于c# - SQLCLR 和 DateTime2,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2620524/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com