Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/csharp/339.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
C# SQLCLR和DateTime2_C#_.net_Tsql_Sql Server 2008_Sqlclr - Fatal编程技术网

C# SQLCLR和DateTime2

C# SQLCLR和DateTime2,c#,.net,tsql,sql-server-2008,sqlclr,C#,.net,Tsql,Sql Server 2008,Sqlclr,使用SQL Server 2008、Visual Studio 2005、.net 2.0和SP2(支持新的SQL Server 2008数据类型) 我正在尝试编写一个SQLCLR函数,它接受一个DateTime2作为输入并返回另一个DateTime2。e、 g: using System; using System.Data.SqlTypes; using Microsoft.SqlServer.Server; namespace MyCompany.SQLCLR { public

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

我正在尝试编写一个SQLCLR函数,它接受一个DateTime2作为输入并返回另一个DateTime2。e、 g:

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,16级,状态2,程序 f_UTCToLocalDT,第1行创建函数 对于“f_UTCToLocalDT”失败,因为 返回值的T-SQL和CLR类型 不匹配


使用DATETIME(而不是DATETIME2)很好。但我宁愿使用DATETIME2来支持更高的精度。我做错了什么,或者SQLCLR不(完全)支持DateTime2吗?

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

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

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

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
请注意,使用“DateTime?”仍然会产生生成错误(即使在sql 2012的VS 2013中),但如果选择“build,deploy”,然后使用obj文件夹中的文件,在执行将其添加到sql Server之前在sql查询窗口中编辑生成的.sql文件(使用DateTime2作为参数),则结果显然是可用的。
生成错误为“SQL46010:附近语法不正确” 在\obj\Debug\YourPrjName.generated.sql中


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

谢谢。这种技术支持传递和返回空值吗?如何调整部署脚本?当您在VisualStudio中右键单击并选择“部署”时,在我不在的地方没有一个。SqlFunction属性的全部要点是自动化该过程,因此您可以从右键单击菜单中选择deploy。。。这不支持null,因为您必须使用Nullable,这似乎不受支持。它甚至在Visual Studio 2010 Ultimate中也无法部署。@MoeSisko:是的,它支持空值。您只需要使用“DateTime?”而不是“DateTime”。我已经对输入参数和返回类型进行了测试,编译后的代码可以在SQLServer2008(在R2上测试)和2012中使用。因为DateTime不是SQL类型,所以您可以通过“==null”而不是像SQL类型一样的“.IsNull”来测试null。@Triynko:是的,事实上支持null。我只是在我之前对教育部的评论中给出了细节,但不能在每条评论中只标记一个人。
DECLARE @input DateTime2, @output DateTime2
SET @input = '2010-04-12 09:53:44.48123456'
SET @output = YourDatabase.dbo.[UTCToLocalDT](@input)
SELECT @input, @output