首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >SQLCLR和DateTime2

SQLCLR和DateTime2
EN

Stack Overflow用户
提问于 2010-04-12 07:39:16
回答 2查看 3.2K关注 0票数 7

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

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

代码语言:javascript
复制
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映射到Server的DateTime2,所以我尝试运行这个T:

代码语言:javascript
复制
CREATE function hubg.f_UTCToLocalDT
(
    @dt DATETIME2
)
returns DATETIME2
AS
EXTERNAL NAME [SQLCLR].[MyCompany.SQLCLR.DateTimeHelpCLR].UTCToLocalDT
GO

这会产生以下错误:

Msg 6551,级别16,状态2,过程f_UTCToLocalDT,第1行创建"f_UTCToLocalDT“函数失败,因为返回值的types和CLR类型不匹配。

使用DATETIME (而不是DATETIME2)可以正常工作。但是我宁愿使用DATETIME2来支持增加的精度。我做错了什么,或者SQLCLR不(完全)支持DateTime2?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2010-04-12 09:05:12

您需要更改函数方法签名中的DateTime类型。SQLDateTime映射到数据库上的DateTime。

System.DateTime更精确,可以映射到DateTime2 (但默认情况下,它将作为部署脚本中的DateTime被删除)。

代码语言:javascript
复制
[SqlFunction(DataAccess = DataAccessKind.None)]
//OLD Signature public static SqlDateTime UTCToLocalDT(SqlDateTime val) 
public static DateTime UTCToLocalDT(DateTime val) {
   ...
}

然后,您可以调整部署脚本以读取。

代码语言:javascript
复制
CREATE FUNCTION [UTCToLocalDT]
(
    @dt [datetime2]
)
RETURNS [datetime2]
AS
    EXTERNAL NAME [SQLCLR].[MyCompany.SQLCLR.DateTimeHelpCLR].UTCToLocalDT
GO

现在,运行您的函数将为您提供更精确的输出。

代码语言:javascript
复制
DECLARE @input DateTime2, @output DateTime2
SET @input = '2010-04-12 09:53:44.48123456'
SET @output = YourDatabase.dbo.[UTCToLocalDT](@input)
SELECT @input, @output
票数 10
EN

Stack Overflow用户

发布于 2014-01-13 02:26:31

注意使用"DateTime?“仍然总是会出现生成错误(即使在VS 2013和sql 2012中也是如此),但是如果选择"build、deploy“然后使用obj文件夹中的文件,在执行将generated.sql文件添加到Server之前,在Server窗口中编辑该文件(使用DateTime2作为参数),结果显然是可用的。

构建错误是"SQL46010:不正确的语法附近)“。在\obj\Debug\YourPrjName.generated.sql中

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

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/2620524

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档