ORA-22828 輸入樣式或替換參數超過了32k大小限制,ora-2282832k

來源:互聯網
上載者:User

ORA-22828 輸入樣式或替換參數超過了32k大小限制,ora-2282832k

今天偵錯工具報以下錯誤:

ORA-22828: input pattern or replacement parameters exceed 32K size limit22828. 00000 -  "input pattern or replacement parameters exceed 32K size limit"*Cause:    Value provided for the pattern or replacement string in the form of           VARCHAR2 or CLOB for LOB SQL functions exceeded the 32K size limit.*Action:   Use a shorter pattern or process a long pattern string in multiple           passes.

可用以下指令碼重現:

declare  cb clob;  ret_cb CLOB;begin  cb := rpad('x', 32767, 'x')||'x';  ret_cb := '<resp>#result#</resp>';  ret_cb := replace(ret_cb, '#result#', cb); end;/


解決方式如下:

編寫函數:

create or replace function replace_with_clob  (i_source in clob  ,i_search in varchar2  ,i_replace in clob  ) return clob is  l_pos pls_integer;begin  l_pos := instr(i_source, i_search);  if l_pos > 0 then    return substr(i_source, 1, l_pos-1)        || i_replace        || substr(i_source, l_pos+length(i_search));  end if;  return i_source;end replace_with_clob;

改寫後:

declare  cb clob;  ret_cb CLOB;begin  cb := rpad('x', 32767, 'x')||'x';  ret_cb := '<resp>#result#</resp>';  ret_cb := replace_with_clob(ret_cb, '#result#', cb);   dbms_output.put_line(substr(ret_cb, 1, 100));end;/

執行成功!



-----------------------------------

Dylan    Presents.



相關文章

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.