格式化时间戳

时间:2019-06-25 17:26:28

标签: sql oracle date to-char

我在表格中有以下日期。

表APEX

id     search_date
 1     04-OCT-18 08.36.12.000000 PM

我希望它显示为以下格式。这可能吗?

id     search_date
 1     10/4/2018 8:36.12

3 个答案:

答案 0 :(得分:2)

我要抑制前导零,可以使用FM开关:

to_char(search_date,'mm/FMdd/yyyy hh:mi.ss') 

如果您也想从月份开始抑制前导零,那应该是

to_char(search_date,'FMmm/dd/yyyy hh:mi.ss') 

请注意,FM充当开关,即您关闭然后打开前导零和空格。

例如'FMmm/FMdd/yyyy hh:mi.ss'的意思是:mm被截断了,而dd/yyyy hh:mi.ss却没有。

答案 1 :(得分:1)

您可以同时使用to_charreplaceltrim字符串运算符函数:

select replace(to_char(search_date,'mm/dd/yyyy '),'/0','/')||
       ltrim(to_char(search_date,'hh:mi.ss'),'0') as search_date
  from apex;

SEARCH_DATE
-----------------
10/4/2018 8:36.12

Demo

答案 2 :(得分:0)

使用TO_CHAR()TO_DATE()

可能是部分答案,输入中没有.000000 PM

SELECT TO_CHAR(TO_DATE('04-OCT-18 08.36.12','DD-MON-YY HH:MI:SS'), 'MM/DD/YYYY HH24:MI:SS') AS Result
FROM DUAL;

结果为10/04/2018 08:36:12


更新:使用TO_CHAR()TO_TIMESTAMP()

SELECT TO_CHAR(TO_TIMESTAMP('04-OCT-18 08.36.12.000000 PM','DD-MON-YY HH:MI:SS.FF PM'), 'MM/DD/YYYY HH24:MI:SS') AS Result
FROM DUAL;

Demo on db<>fiddle,将作为10/04/2018 20:36:12

使用此04-OCT-18 08.36.12.000000 AM将得到10/04/2018 08:36:12demo相同。