转换日期用户定义的函数不起作用

Posted

技术标签:

【中文标题】转换日期用户定义的函数不起作用【英文标题】:Convert Date user-defined function not working 【发布时间】:2013-02-15 11:29:35 【问题描述】:

您好,我正在尝试在 SQL Server 2008 中创建一个用户定义的函数,以将日期从一种格式转换为另一种格式。

我使用的日期缺少世纪,即 1610101 是 1961/01/01,而 213/02/15 实际上是 2013/02/15。

我已经在这几个网站上搜索了一个很好的解决方案,但我看不出它有什么问题。

create function Convert_Date(@Cdate Date)
returns Date
as
Begin
declare @return date
select @return = case @Cdate
when (LEFT(@Cdate,1) = 1) then convert(date,('19'+ CONVERT(VARCHAR(30), right(@Cdate,6))))
when (LEFT(@Cdate,1) = 2) then convert(date,('20'+ CONVERT(VARCHAR(30), right(@Cdate,6))))
return @return
end

【问题讨论】:

【参考方案1】:

你想要这样的东西:

CREATE FUNCTION Convert_Date(@Cdate DATE)
RETURNS DATE
AS
BEGIN

    DECLARE @return DATE

    SELECT @return = 
    (
        CASE LEFT(@Cdate,1) 
            WHEN '1' THEN CONVERT(DATE, ('19'+ CONVERT(VARCHAR(30), RIGHT(@Cdate,6)))) 
            WHEN '2' THEN CONVERT(DATE, ('20'+ CONVERT(VARCHAR(30), RIGHT(@Cdate,6))))
        END
    )

    RETURN @return
END

您的 when 语句应该是您的结果与 case 匹配的时间 when

【讨论】:

它说它缺少声明行,所以我添加了它并且它有效。感谢一百万詹姆斯。 我已经整理了它,所以它会帮助遇到答案的其他人。如果您可以将我的回复标记为您问题的答案,那就太好了

以上是关于转换日期用户定义的函数不起作用的主要内容,如果未能解决你的问题,请参考以下文章

.getDay() 在将日期转换为特定时区时不起作用

如果用户定义函数中的语句不起作用

将纪元时间戳转换为可读日期不起作用

将纪元转换为人类可读的日期在 python 中不起作用

通过 PHP 显示时 MSSQL 查询中的日期转换不起作用

pyspark:用于确定 NaN 或 Null 的用户定义函数不起作用