Oracle SQL中的时间戳转换

时间:2015-02-22 15:04:29

标签: sql oracle sql-timestamp

我使用的是Oracle SQL,而且我有一个日期问题。

我有一个包含许多Insert命令的长脚本,例如:

Insert into MyTable 
(TIME,CROSS,BID,ASK) 
values (to_timestamp('13-NOV-14 03.38.27.785000000 PM','DD-MON-RR HH.MI.SSXFF AM'),'USD/CHF',0.96294,0.963);

但是,我收到以下错误:

ORA-01843 -  "not a valid month"

这是sysdate格式:

22-FEB-15 04.57:18

我尝试了以下命令,我收到格式错误:

alter session set nls_date_format = 'DD-MON-RR HH.MI:SSXFF';

我该如何解决这个问题? 另外,我想将这些日期转换为以下格式:

DD/MM/YYYY HH24:MI:SS.miliseconds

此转换可以在insert命令中吗?

请告知

1 个答案:

答案 0 :(得分:4)

怀疑您的 locale_specific NLS_DATE_LANGUAGE 不同。

使用 to_timestamp 中包含的 NLS_DATE_LANGUAGE 参数尝试以下查询:

to_timestamp('13-NOV-14 03.38.27.785000000 PM','DD-MON-RR HH.MI.SSXFF AM','NLS_DATE_LANGUAGE = AMERICAN')

有关更改会话的另一种选择,请参阅this