首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >将格式为YYMMDD的VARCHAR转换为YYYYMMDD并忽略无效的日期格式

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

Stack Overflow用户
提问于 2017-03-01 15:22:55
回答 4查看 4.6K关注 0票数 1

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

然而,我的问题是,当不适当的数据输入到字段中时,我需要处理这种情况,并且我的查询需要排除这些数据。我通过使用TSQL的ISDATE函数来实现这种排除。我还需要选择最近的条目(为此我使用order by asc )。

我正在使用各种转换来编写这个查询,下面是我的实现,其中包含一个示例表和数据。

代码语言:javascript
复制
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的错误,这会破坏查询。有没有人能告诉我写这个功能的更好的方法。

非常感谢!

EN

回答 4

Stack Overflow用户

回答已采纳

发布于 2017-03-01 17:18:31

您可以使用TRY_CONVERT(https://msdn.microsoft.com/query/dev10.query?appId=Dev10IDEF1&l=EN-US&k=k(TRY_CONVERT_TSQL%29;k(SQL11.SWB.TSQLRESULTS.F1%29;k(SQL11.SWB.TSQLQUERY.F1%29;k(MISCELLANEOUSFILESPROJECT%29;k(DevLang-TSQL%29&rd=true)和CONVERT(https://msdn.microsoft.com/query/dev10.query?appId=Dev10IDEF1&l=EN-US&k=k(CAST_TSQL%29;k(SQL11.SWB.TSQLRESULTS.F1%29;k(SQL11.SWB.TSQLQUERY.F1%29;k(MISCELLANEOUSFILESPROJECT%29;k(DevLang-TSQL%29&rd=true)来获取正确的格式并转换值。然后检查字符串是否恰好是6个字符,以防止返回其他格式。

代码语言:javascript
复制
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
票数 1
EN

Stack Overflow用户

发布于 2017-03-01 15:31:38

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

代码语言:javascript
复制
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
EN

Stack Overflow用户

发布于 2017-03-01 15:35:15

请使用create function检查dateformat是否有效,并在cash clouse中使用这个有趣的查询。

代码语言:javascript
复制
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

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

https://stackoverflow.com/questions/42525574

复制
相关文章

相似问题

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