将格式为YYMMDD的VARCHAR转换为YYYYMMDD并忽略无效的日期格式

时间:2017-03-01 07:22:55

标签: sql-server tsql date stored-procedures

我有一个带有名为ArrivalDate的VARCHAR字段的表,其格式为yymmdd(例如170202)。 我正在编写一个查询,将其转换为yyyymmdd,因此它应该成为20170202.

但是我的问题是我需要满足在不正确的数据输入字段时的情况,并且我的查询需要排除该数据。我通过使用TSQL的ISDATE函数实现了这种排除。我还需要选择最近的条目(我使用asc命令)。

我使用各种转换器来编写此查询,下面是我的实现,带有示例表和数据。

Declare @tmp TABLE (theDates VARCHAR(MAX))

INSERT INTO @tmp VALUES('170202')

SELECT TOP 1 t.theDates
WHEN (ISDATE(t.theDates) = 1) THEN CONVERT( VARCHAR(max),CONVERT(datetime t.theDates), 112)
FROM @tmp t
WHERE (ISDATE(t.theDates) = 1)
ORDER BY CAST(t.theDates as DATE)

但是我不喜欢我的方法,它偶尔会失败转换并抛出错误,例如02/02/02这样会破坏查询。有人可以告诉我一个更好的方法来编写这个功能。

非常感谢!

4 个答案:

答案 0 :(得分:1)

您可以使用cast(@date as datetime)

declare @date varchar(max);
    set @date='170202';
    select
    CASE WHEN (ISDATE(cast(@date as datetime)) = 1) 
        THEN CONVERT(VARCHAR(max), CONVERT(datetime,  cast(@date as datetime)), 112) end
        from table

    set @date='02/02/02';
    select
    CASE WHEN (ISDATE(cast(@date as datetime)) = 1) 
        THEN CONVERT(VARCHAR(max), CONVERT(datetime,  cast(@date as datetime)), 112) end
        from table

答案 1 :(得分:1)

您可以使用TRY_CONVERTCONVERT来获取正确的格式并转换价值。然后检查字符串是否正好是6个字符,以防止返回其他格式。

SELECT
  convert(char(10),convert(date, theDates, 12),112)
FROM
  (values('02/02/02'),('170202')) x(theDates)
WHERE
  try_convert(date, theDates, 12) is not null
  and len(theDates) = 6

答案 2 :(得分:0)

请使用创建功能检查dateformat是否有效,并在现金clouse内查询中使用此乐趣。

ALTER  FUNCTION dbo.f_CheckDate
(@InDate nvarchar(25))
RETURNS DATE
AS
    BEGIN
        declare @Return DATETIME
        select @return = CASE WHEN ISDATE(@InDate) = 1
                             THEN   @InDate
                            ELSE NULL
                            END
        return @return
    END

答案 3 :(得分:0)

您可以使用TRY_CASTTRY_CONVERT如果无法转换值,它将返回NULL。

SELECT 
  TRY_CAST('20170228' AS DATETIME),
  TRY_CAST('170228' AS DATETIME),
  TRY_CONVERT(DATETIME, '20170228'),
  TRY_CONVERT(DATETIME, '170228')

这适用于SQL Server 2012及更高版本。