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

ब्लॉब कॉलम के साथ Oracle पर परीक्षण डेटा तैयार करें

यदि आपको परवाह नहीं है कि LOB डेटा की सामग्री समान है, तो आप निम्न का उपयोग कर सकते हैं (एक यादृच्छिक 10000 बाइट्स लॉब मान बनाना):

declare
   v_clob        clob;
   v_blob        blob;
   v_dest_offset integer := 1;
   v_src_offset  integer := 1;
   v_warn        integer;
   v_ctx         integer := dbms_lob.default_lang_ctx;
begin
   for idx in 1..5
   loop
     v_clob := v_clob || dbms_random.string('x', 2000);
   end loop;
   dbms_lob.createtemporary( v_blob, false );
   dbms_lob.converttoblob(v_blob,
                          v_clob,
                          dbms_lob.lobmaxsize,
                          v_dest_offset,
                          v_src_offset,
                          dbms_lob.default_csid,
                          v_ctx,
                          v_warn);
   insert into blob_test (id, data)
     select rownum, v_blob from dual
     connect by level <= 10000;
end;
/

यहां एक उदाहरण सत्र देखें:

SQL> create table blob_test (id number primary key, data blob);

Table created.

SQL> declare
  2    v_clob        clob;
  3    v_blob        blob;
  4    v_dest_offset integer := 1;
  5    v_src_offset  integer := 1;
  6    v_warn        integer;
  7    v_ctx         integer := dbms_lob.default_lang_ctx;
  8  begin
  9    for idx in 1..5
 10    loop
 11      v_clob := v_clob || dbms_random.string('x', 2000);
 12    end loop;
 13    dbms_lob.createtemporary( v_blob, false );
 14    dbms_lob.converttoblob(v_blob,
 15                           v_clob,
 16                            dbms_lob.lobmaxsize,
 17                           v_dest_offset,
 18                           v_src_offset,
 19                           dbms_lob.default_csid,
 20                           v_ctx,
 21                           v_warn);
 22
 23    insert into blob_test (id, data)
 24    select rownum, v_blob
 25      from dual
 26     connect by level <= 10000;
 27
 28  end;
 29  /

PL/SQL procedure successfully completed.


SQL> select count(*) , max(length(data)) from blob_test;

  COUNT(*) MAX(LENGTH(DATA))
---------- -----------------
     10000             10000

यदि आप अलग-अलग डेटा चाहते हैं तो आप v_lob . उत्पन्न और सम्मिलित कर सकते हैं इसके बजाय एक लूप में।




  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Oracle के ADD_MONTHS () का SQL सर्वर संस्करण

  2. टाइपओआरएम सबक्वेरी

  3. ओरेकल में मौजूदा खाते के समान विशेषाधिकारों के साथ स्कीमा को कैसे दोहराएं?

  4. राय मांगना :सभी तालिकाओं के लिए एक क्रम

  5. नेटवर्क अस्थिर होने पर मैं अपने डीबी कनेक्शन को विफल होने से कैसे रोक सकता हूं?