0

我有一个包含生日属性的数据集。日期格式为M/D/YYYY(单个数字表示,例如 2009 年 5 月 8 日)并以文本格式存储。现在,我需要将列类型更改为日期。但是,有许多实体(可以手动修复更多)具有部分日期 - 即缺少日期或缺少日期和月份。例如:

"//1935"
"/5/1929"
"/4/1931"

现在,当我申请时,to_date(birthdate,'DD/MM/YYYY')我收到错误,因为 Postgresql 无法解析这些日期。我需要做的是用默认值填充缺失值。例如,"//1935""/5/1929"应该分别转换为"1/1/1935""1/5/1929"。有没有快速解决这个问题的方法?或者,我是否需要编写正则表达式解析器?

4

1 回答 1

1

SQL Fiddle Demo

CREATE TABLE product
    ("inputDate" varchar(9))
;

INSERT INTO product
    ("inputDate")
VALUES
    ('//1935'),
    ('/5/1929'),
    ('/4/1931')
;

SELECT *,
       CASE WHEN substr("inputDate", 1, 2) = '//' THEN '1/1/' || substr("inputDate", 3, 10)
            WHEN substr("inputDate", 1, 1) = '/' THEN '1/' || substr("inputDate", 2, 10)
            ELSE "inputDate"
       END as result
FROM Product;
于 2016-04-06T16:27:51.433 回答