7

使用 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 ?

4

2 回答 2

10

您需要更改函数方法签名中的 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
于 2010-04-12T09:05:12.857 回答
1

请注意,使用“日期时间?” 仍然总是给出构建错误(即使在带有 sql 2012 的 VS 2013 中),但显然如果选择“构建,部署”然后使用 obj 文件夹中的文件,在 sql 查询窗口中编辑 generate.sql 文件,结果是可用的(使用 DateTime2 作为参数)在执行之前将其添加到 Sql Server。
构建错误是“SQL46010: ) 附近的语法不正确。” 在 \obj\Debug\YourPrjName.generated.sql

(如果可以的话,会在上面发表评论。)

于 2014-01-13T02:26:31.127 回答