在 sqlplus / Oracle 中将纪元转换为日期
我有下表:
SQL> desc recording
Name Null? Type
-------------------- -------- ------
CAPTUREID NOT NULL NUMBER(9)
STARTDATE NOT NULL DATE
ENDDATE DATE
STATE NUMBER(1)
ESTIMATEDENDTIME NUMBER(13)
这是该表的一行:
SQL> select * from recording where CAPTUREID=14760457;
CAPTUREID STARTDATE ENDDATE STATE ESTIMATEDENDTIME
---------- ------------------- ------------------- ----- ----------------
14760457 29/09/2010 08:50:01 29/09/2010 09:52:04 0 1285746720000
我很确定以前已经多次询问过这个问题,但到目前为止我找到的所有解决方案都没有真正起作用,所以......如何如何在 SQLPLUS 中的单个查询中将 ESTIMATEDENDTIME
从其原始纪元形式转换为 DD/MM/YYY HH:MI:SS
格式?
谢谢!
I have the following table:
SQL> desc recording
Name Null? Type
-------------------- -------- ------
CAPTUREID NOT NULL NUMBER(9)
STARTDATE NOT NULL DATE
ENDDATE DATE
STATE NUMBER(1)
ESTIMATEDENDTIME NUMBER(13)
Here's a single line for this table:
SQL> select * from recording where CAPTUREID=14760457;
CAPTUREID STARTDATE ENDDATE STATE ESTIMATEDENDTIME
---------- ------------------- ------------------- ----- ----------------
14760457 29/09/2010 08:50:01 29/09/2010 09:52:04 0 1285746720000
I'm pretty sure that this has been asked so many times before, but all the solutions I've found so far didn't really work, so... How do I convert ESTIMATEDENDTIME
from its original epoch form to a DD/MM/YYY HH:MI:SS
format in a single query in SQLPLUS?
Thanks!
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(2)
在 Oracle 中,将 X 添加到 DATE 将在 X 天后返回 DATE。
如果 ESTIMATEDENDTIME 是自 Epoch 以来的毫秒数,那么您可以这样做
,然后使用 to_char 来实现结果日期的正确格式。例如:
In Oracle, adding X to a DATE will return you a DATE X days later.
If ESTIMATEDENDTIME is milliseconds since Epoch then you could do
and then use to_char to achieve the correct format of the resulting date. e.g: