我使用的是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命令中吗?
请告知
答案 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。