Oracle
 sql >> डेटाबेस >  >> RDS >> Oracle

CLOB के साथ REPLACE को कॉल कैसे करें (32K से अधिक के बिना)

यहां एक फ़ंक्शन के लिए एक मोटा पहला मसौदा है जो कुछ सीमाओं के साथ काम करेगा, इसका अभी तक बहुत अच्छी तरह से परीक्षण नहीं किया गया है:

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
  v2 varchar2(32767);
  cl_small clob;
  cl_big clob;
  cl_big2 clob;
begin
  v2 := rpad('x', 32767, 'x');
  dbms_output.put_line('v2:' || length(v2));
  cl_small := v2;
  dbms_output.put_line('cl_small:' || length(cl_small));
  cl_big := v2 || 'y' || v2;
  dbms_output.put_line('cl_big[1]:' || length(cl_big));
  cl_big2 := replace(cl_big, 'y', cl_small);
  dbms_output.put_line('cl_big[2]:' || length(cl_big2));
  cl_big2 := replace_with_clob(cl_big, 'y', cl_big); 
  dbms_output.put_line('cl_big[3]:' || length(cl_big2));
end;
/

v2:32767
cl_small:32767
cl_big[1]:65535
cl_big[2]:98301
cl_big[3]:131069


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. 2000 या 4000 बाइट्स से बड़ा BLOB टेस्ट स्ट्रिंग डालें

  2. विभिन्न SQL कथनों के साथ तैयार स्टेटमेंट बैचिंग

  3. दो तालिकाओं को मिलाएं और अतिव्यापी तिथियां और अंतराल खोजें

  4. Oracle ट्रिगर इंसर्ट/अपडेट

  5. MyBatis का उपयोग करके Oracle संग्रहीत कार्यविधि में जावा वस्तुओं की सूची कैसे पास करें?