convert函式引起的ora-01482錯誤

myownstars發表於2011-08-12

開發報告測試庫上執行一段sql遇到以下錯誤

select ID,name
         ,decode(sign(sysdate-nvl(begin_date,sysdate)) + sign(nvl(invite_end_date,sysdate)-sysdate),2,1,0) showInviteCode
    From   JUSTIN
    where IS_DELETE = 0
    and   NVL(MAIL_DNS,' ')<> ' '
order by  convert(name,'ZHS16CGB231280','UTF8')
 
ORA-01482: unsupported character set
剛開始被錯誤提示資訊誤導了,以為是字符集不支援;檢視檢視發現不是這回事
SQL> select * from v$nls_valid_values where parameter='CHARACTERSET' and value='ZHS16CGB231280';
 
PARAMETER                      VALUE                          ISDEPRECATED
------------------------------ ------------------------------ ------------
CHARACTERSET                   ZHS16CGB231280                 FALSE

檢視alert log也沒有發現有價值的東西,metalink上搜一把,有篇文章說是記憶體錯誤,trace file裡會出現ora-4031;
但是alert log裡的ora-4031錯誤是12個小時之前報的了,不會到現在還存在吧;
嘗試情況shared_pool
SQL> alter system flush shared_pool;

System altered.
但是依然報錯,將shared_pool增大到300m
SQL> show parameter shared_pool

NAME                                 TYPE        VALUE
------------------------------------ ----------- ------------------------------
shared_pool_reserved_size            big integer 12M
shared_pool_size                     big integer 240M
SQL> alter system set shared_pool_size = 300m;

System altered.
這次執行成功了
看來這個covert函式跟shared_pool還是有很大關係的

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/15480802/viewspace-704766/,如需轉載,請註明出處,否則將追究法律責任。

相關文章