有没有办法将6位数的序数日期(公元0001年1月1日以来的天数)转换为Postgres的正常时间戳?使用python的datetime.toordinal()创建日期.
例如,
>>> date = datetime.date(2010, 7, 20)
>>> datetime.toordinal(date)
733973
我需要的是在Postgres中将’733973’转换回’2010-07-20′.
谢谢!
解决方法:
这是我首先想到的:
select date (date '0000-12-31' + interval '733973 days');
>> "2010-07-20"
要么
select date (date '0000-12-31' + interval '1 days' * 733973);
>> "2010-07-20"
它只是将截止日期添加到0000-12-31的日期.它不使用日期0001-01-01,因为datetime.toordinal()被定义为此日期为1,因此-1偏移量.
date.fromordinal(ordinal)
Return the date corresponding to the proleptic Gregorian ordinal, where
January 1 of year 1 has ordinal 1…
编辑:
如果将期限0000-31-12未被识别为有效日期,您可以轻松地将语句更改为:
select date (date '0001-01-01' + interval '733973 days' - interval '1 day');
要么
select date (date '0001-01-01' + (interval '1 days' * (733973 - 1)));
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。