如何检查SQL Server中是否存在多种日期格式?

时间:2019-07-17 08:01:37

标签: sql sql-server

我需要检查sql server的同一列中是否存在多个日期格式?

列的数据类型为nvarchar

drop table dateformats

create table dateformats(datevalue varchar(50))

insert dateformats
values ('01-january-2019'),('31-JAN-2019'),('2019-01-01'),
('16-07-2019'),('20-12-2019'),('16-10-2019'),('16-AUG-2019'),('AUG-07-2019'),('16/07/2019'),('07/16/2019'),('01-jan-2019'),('01-january-2019'),(''),(NULL)

SELECT datevalue  
FROM dateformats

返回以显示该列具有多种日期格式的查询。

2 个答案:

答案 0 :(得分:0)

您可以使用set(gca,'XMinorTick','Off') group by

having

答案 1 :(得分:0)

您可以尝试使用此查询。

现在,我在查询中固定了DMYMDY这4种格式,但是如果数组或SQL表中已经具有所有格式,则可以在查询中使用它。

此查询将返回在表的特定列中使用的所有日期格式

SET DATEFORMAT dmy 
SELECT formats into #temp FROM (

SELECT 
max( 
CASE WHEN isdate(datevalue) = 1 then
(CASE WHEN CAST(datevalue AS VARCHAR(50)) = CAST(FORMAT(CAST(datevalue AS DATE),'dd-MM-yyyy') AS VARCHAR(50)) THEN 'dd-MM-yyyy' ELSE '' END)
ELSE '' END )
AS formats from dateformats 

UNION 

SELECT 
max( 
CASE WHEN isdate(datevalue) = 1 then
(CASE WHEN CAST(datevalue AS VARCHAR(50)) = CAST(FORMAT(CAST(datevalue AS DATE),'dd/MM/yyyy') AS VARCHAR(50)) THEN 'dd/MM/yyyy' ELSE '' END)
ELSE '' END )
AS formats from dateformats 

UNION 

SELECT 
max( 
CASE WHEN isdate(datevalue) = 1 then
(CASE WHEN CAST(datevalue AS VARCHAR(50)) = CAST(FORMAT(CAST(datevalue AS DATE),'dd-MMM-yyyy') AS VARCHAR(50)) THEN 'dd-MMM-yyyy' ELSE '' END) 
ELSE '' END )
AS formats from dateformats

) AS a

WHERE formats <> '';

  set dateformat MDY  insert into #temp
    SELECT formats  FROM (

    SELECT 
    max( 
    CASE WHEN isdate(datevalue) = 1 then
    (CASE WHEN CAST(datevalue AS VARCHAR(50)) = CAST(FORMAT(CAST(datevalue AS DATE),'MM-dd-yyyy') AS VARCHAR(50)) THEN 'MM-dd-yyyy' ELSE '' END)
    ELSE '' END )
    AS formats from dateformats 

    UNION 

    SELECT 
    max( 
    CASE WHEN isdate(datevalue) = 1 then
    (CASE WHEN CAST(datevalue AS VARCHAR(50)) = CAST(FORMAT(CAST(datevalue AS DATE),'MM/dd/yyyy') AS VARCHAR(50)) THEN 'MM/dd/yyyy' ELSE '' END) 
    ELSE '' END )
    AS formats from dateformats

    ) AS b

    WHERE formats <> '';

select * from #temp

DEMO