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

來源:互聯網
上載者:User

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

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

ORA-22828: input pattern or replacement parameters exceed 32K size limit
22828. 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.

 

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

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.