我有一个表,其中包含一个名为ArrivalDate的VARCHAR字段,格式为yymmdd (例如170202)。我正在编写一个查询,将其转换为yyyymmdd,因此它应该变为20170202。
然而,我的问题是,当不适当的数据输入到字段中时,我需要处理这种情况,并且我的查询需要排除这些数据。我通过使用TSQL的ISDATE函数来实现这种排除。我还需要选择最近的条目(为此我使用order by 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的错误,这会破坏查询。有没有人能告诉我写这个功能的更好的方法。
非常感谢!
发布于 2017-03-01 15:35:15
请使用create function检查dateformat是否有效,并在cash 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
https://stackoverflow.com/questions/42525574
复制相似问题