日韩黑丝制服一区视频播放|日韩欧美人妻丝袜视频在线观看|九九影院一级蜜桃|亚洲中文在线导航|青草草视频在线观看|婷婷五月色伊人网站|日本一区二区在线|国产AV一二三四区毛片|正在播放久草视频|亚洲色图精品一区

分享

ORA-01855: AM/A.M. or PM/P.M. required問題排查與解析

 Jimmy Booker 2012-09-26

1.【問題現(xiàn)象】
在中文Windows環(huán)境的SQL*Plus中使用如下日期操作SQL時(shí)報(bào)錯(cuò)。具體報(bào)錯(cuò)信息如下:
sec@ora10g> insert into t values (TO_Date( '10/22/2009 12:00:00 AM', 'MM/DD/YYYY HH:MI:SS AM'));
insert into t values (TO_Date( '10/22/2009 12:00:00 AM', 'MM/DD/YYYY HH:MI:SS AM'))
                               *
第 1 行出現(xiàn)錯(cuò)誤:
ORA-01855: AM/A.M. or PM/P.M. required

sec@ora10g> select TO_Date( '10/22/2009 12:00:00 AM', 'MM/DD/YYYY HH:MI:SS AM') from dual;
select TO_Date( '10/22/2009 12:00:00 AM', 'MM/DD/YYYY HH:MI:SS AM') from dual
                *
第 1 行出現(xiàn)錯(cuò)誤:
ORA-01855: AM/A.M. or PM/P.M. required

2.【問題原因】
在本地NLS_DATE_LANGUAGE參數(shù)指定的語言中沒有找到“AM”這樣的時(shí)間定義,也就是說在具體的國家語言下此類“AM”的定義是不相同的,比如,在中文“SIMPLIFIED CHINESE”中就應(yīng)該指定為“上午/下午”,在美國的語言中就應(yīng)該指定為“A.M. / P.M.”,在英國語言或西歐語言中就要指定為“AM/PM”。注意其中的區(qū)別。

這里給出一種查詢NLS_DATE_LANGUAGE參數(shù)的方法:
sec@ora10g> col PARAMETER for a30
sec@ora10g> col VALUE for a30
sec@ora10g> select * from v$nls_parameters;

PARAMETER                      VALUE
------------------------------ ------------------------------
NLS_LANGUAGE                   SIMPLIFIED CHINESE
NLS_TERRITORY                  CHINA
NLS_CURRENCY                   ¥
NLS_ISO_CURRENCY               CHINA
NLS_NUMERIC_CHARACTERS         .,
NLS_CALENDAR                   GREGORIAN
NLS_DATE_FORMAT                DD-MON-RR
NLS_DATE_LANGUAGE              SIMPLIFIED CHINESE
NLS_CHARACTERSET               AL32UTF8
NLS_SORT                       BINARY
NLS_TIME_FORMAT                HH.MI.SSXFF AM
NLS_TIMESTAMP_FORMAT           DD-MON-RR HH.MI.SSXFF AM
NLS_TIME_TZ_FORMAT             HH.MI.SSXFF AM TZR
NLS_TIMESTAMP_TZ_FORMAT        DD-MON-RR HH.MI.SSXFF AM TZR
NLS_DUAL_CURRENCY              ¥
NLS_NCHAR_CHARACTERSET         UTF8
NLS_COMP                       BINARY
NLS_LENGTH_SEMANTICS           BYTE
NLS_NCHAR_CONV_EXCP            FALSE

已選擇19行。

3.【問題處理】 方法很簡單,第一類處理方法就是嚴(yán)格按照具體國家語言的定義格式書寫特定的時(shí)間字符串,另一類處理方法是修改NLS_DATE_LANGUAGE參數(shù)以便適應(yīng)某一種日期字符串的寫法。下面從這兩類處理思想出發(fā),給出三種可行的處理方法。
1)第一種方法:將原字符串中的“AM”修改為中國特色的的“上午”
sec@ora10g> select TO_Date( '22/10/2009 12:00:00 上午', 'DD/MM/YYYY HH:MI:SS AM') from dual;

TO_DATE('22/10
--------------
22-10月-09

sec@ora10g> alter session set NLS_DATE_FORMAT='MM/DD/YYYY HH:MI:SS AM';

會話已更改。

sec@ora10g> select TO_Date( '22/10/2009 12:00:00 上午', 'DD/MM/YYYY HH:MI:SS AM') from dual;

TO_DATE('22/10/200912:00
------------------------
10/22/2009 12:00:00 上午

2)第二種處理方法:直接在session中修改NLS_DATE_LANGUAGE參數(shù),即刻生效。
(1)修改NLS_DATE_LANGUAGE為“AMERICAN”
sec@ora10g> alter session set NLS_DATE_LANGUAGE = 'AMERICAN';

會話已更改。

(2)再一次嘗試查詢,此時(shí)已經(jīng)不再報(bào)錯(cuò)
sec@ora10g> select TO_Date( '10/22/2009 12:00:00 AM', 'MM/DD/YYYY HH:MI:SS AM') from dual;

TO_DATE('10/
------------
22-OCT-09

(3)格式化一下日期格式,以便更加清晰的查看結(jié)果。
sec@ora10g> alter session set NLS_DATE_FORMAT='MM/DD/YYYY HH:MI:SS AM';

會話已更改。

sec@ora10g> select TO_Date( '10/22/2009 12:00:00 AM', 'MM/DD/YYYY HH:MI:SS AM') from dual;

TO_DATE('10/22/200912:
----------------------
10/22/2009 12:00:00 AM

3)第三種方法:修改Windows注冊表中的NLS_LANG參數(shù),以便達(dá)到迂回的修改NLS_DATE_FORMAT參數(shù)的目的
(1)進(jìn)入Windows注冊表方法
點(diǎn)擊Windows操作系統(tǒng)的左下角的“開始”(“start”),然后點(diǎn)擊“運(yùn)行”(Run),最后輸入“regedit”回車后便可進(jìn)入到注冊表界面。

(2)在注冊表中按照下面的過程導(dǎo)航,即可定位到NLS_LANG變量
“My Computer” --> “HKEY_LOCAL_MACHINE” --> “SOFTWARE” --> “ORACLE” --> “KEY-OraDb10g_home1”
此時(shí)在注冊表的右側(cè)就能發(fā)現(xiàn)“NLS_LANG”的身影了

(3)雙擊“NLS_LANG”,把內(nèi)容替換為“AMERICAN_AMERICA.ZHS16GBK”或“AMERICAN_CHINA.ZHS16GBK”即可(NLS_LANG的第一部分“語言”起作用)。

(4)驗(yàn)證查詢
sec@ora10g> select TO_Date( '10/22/2009 12:00:00 AM', 'MM/DD/YYYY HH:MI:SS AM') from dual;

TO_DATE('10/
------------
22-OCT-09

sec@ora10g> alter session set NLS_DATE_FORMAT='MM/DD/YYYY HH:MI:SS AM';

Session altered.

sec@ora10g> select TO_Date( '10/22/2009 12:00:00 AM', 'MM/DD/YYYY HH:MI:SS AM') from dual;

TO_DATE('10/22/200912:
----------------------
10/22/2009 12:00:00 AM

4.小結(jié)
Oracle的日期操作本身相對其他數(shù)據(jù)類型操作來說復(fù)雜很多,在日常的使用過程中要多加總結(jié)與記錄。
鑒于本文中提到的問題,在書寫腳本的時(shí)候或使用工具生成腳本的時(shí)候,一定要注意腳本中日期類字符串的書寫格式。以防因此導(dǎo)致數(shù)據(jù)無法錄入。

    本站是提供個(gè)人知識管理的網(wǎng)絡(luò)存儲空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點(diǎn)。請注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購買等信息,謹(jǐn)防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請點(diǎn)擊一鍵舉報(bào)。
    轉(zhuǎn)藏 分享 獻(xiàn)花(0

    0條評論

    發(fā)表

    請遵守用戶 評論公約