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

ऑरैकल 9i में सीएसवी स्ट्रिंग्स को सर्वश्रेष्ठ तरीके से कैसे विभाजित करें?

जॉयस,

यहां तीन उदाहरण दिए गए हैं:

1) dbms_utility.comma_to_table का उपयोग करना। यह एक सामान्य प्रयोजन दिनचर्या नहीं है, क्योंकि तत्वों को मान्य पहचानकर्ता होना चाहिए। कुछ गंदी तरकीबों से हम इसे और अधिक सार्वभौमिक बना सकते हैं:

SQL> declare
  2    cn_non_occuring_prefix constant varchar2(4) := 'zzzz';
  3    mystring varchar2(2000):='a:sd:dfg:31456:dasd: :sdfsdf'; -- just an example
  4    l_tablen binary_integer;
  5    l_tab    dbms_utility.uncl_array;
  6  begin
  7    dbms_utility.comma_to_table
  8    ( list   => cn_non_occuring_prefix || replace(mystring,':',','||cn_non_occuring_prefix)
  9    , tablen => l_tablen
 10    , tab    => l_tab
 11    );
 12    for i in 1..l_tablen
 13    loop
 14      dbms_output.put_line(substr(l_tab(i),1+length(cn_non_occuring_prefix)));
 15    end loop;
 16  end;
 17  /
a
sd
dfg
31456
dasd

sdfsdf

PL/SQL-procedure is geslaagd.

2) एसक्यूएल के स्तर से कनेक्ट का उपयोग करना। यदि आप 10g या उच्चतर पर हैं, तो आप नियमित अभिव्यक्तियों के संयोजन में कनेक्ट-बाय-लेवल दृष्टिकोण का उपयोग कर सकते हैं, जैसे:

SQL> declare
  2    mystring varchar2(2000):='a:sd:dfg:31456:dasd: :sdfsdf'; -- just an example
  3  begin
  4    for r in
  5    ( select regexp_substr(mystring,'[^:]+',1,level) element
  6        from dual
  7     connect by level <= length(regexp_replace(mystring,'[^:]+')) + 1
  8    )
  9    loop
 10      dbms_output.put_line(r.element);
 11    end loop;
 12  end;
 13  /
a
sd
dfg
31456
dasd

sdfsdf

PL/SQL-procedure is geslaagd.

3) फिर से एसक्यूएल के स्तर से कनेक्ट का उपयोग करना, लेकिन अब अच्छे पुराने SUBSTR/INSTR के संयोजन में यदि आप संस्करण 9 पर हैं, जैसे आप हैं:

    SQL> declare
      2    mystring varchar2(2000):='a:sd:dfg:31456:dasd: :sdfsdf'; -- just an example
      3  begin
      4    for r in
      5    ( select substr
      6             ( str
      7             , instr(str,':',1,level) + 1
      8             , instr(str,':',1,level+1) - instr(str,':',1,level) - 1
      9             ) element
     10        from (select ':' || mystring || ':' str from dual)
     11     connect by level <= length(str) - length(replace(str,':')) - 1
     12    )
     13    loop
     14      dbms_output.put_line(r.element);
     15    end loop;
     16  end;
     17  /
    a
    sd
    dfg
    31456
    dasd

    sdfsdf

PL/SQL-procedure is geslaagd.

आप इस तरह की कुछ और तकनीकें इस ब्लॉगपोस्ट में देख सकते हैं:http://rwijk.blogspot.com/2007/11/interval-based-row-generation.html

आशा है कि यह मदद करता है।

सादर, रोब।

अपनी टिप्पणी को संबोधित करने के लिए:

एक सामान्यीकृत तालिका में अलग किए गए मानों को सम्मिलित करने का एक उदाहरण।

पहले टेबल बनाएं:

SQL> create table csv_table (col)
  2  as
  3  select 'a,sd,dfg,31456,dasd,,sdfsdf' from dual union all
  4  select 'a,bb,ccc,dddd' from dual union all
  5  select 'zz,yy,' from dual
  6  /

Table created.

SQL> create table normalized_table (value varchar2(10))
  2  /

Table created.

क्योंकि आप dbms_utility.comma_to_table दृष्टिकोण में रुचि रखते हैं, मैं यहाँ इसका उल्लेख करता हूँ। हालांकि, मैं निश्चित रूप से इस प्रकार की अनुशंसा नहीं करता, क्योंकि पहचानकर्ता विचित्रता और पंक्ति प्रसंस्करण द्वारा धीमी पंक्ति के कारण।

SQL> declare
  2    cn_non_occuring_prefix constant varchar2(4) := 'zzzz';
  3    l_tablen binary_integer;
  4    l_tab    dbms_utility.uncl_array;
  5  begin
  6    for r in (select col from csv_table)
  7    loop
  8      dbms_utility.comma_to_table
  9      ( list   => cn_non_occuring_prefix || replace(r.col,',',','||cn_non_occuring_prefix)
 10      , tablen => l_tablen
 11      , tab    => l_tab
 12      );
 13      forall i in 1..l_tablen
 14        insert into normalized_table (value)
 15        values (substr(l_tab(i),length(cn_non_occuring_prefix)+1))
 16      ;
 17    end loop;
 18  end;
 19  /

PL/SQL procedure successfully completed.

SQL> select * from normalized_table
  2  /

VALUE
----------
a
sd
dfg
31456
dasd

sdfsdf
a
bb
ccc
dddd
zz
yy


14 rows selected.

मैं इस एकल SQL संस्करण की अनुशंसा करता हूं:

SQL> truncate table normalized_table
  2  /

Table truncated.

SQL> insert into normalized_table (value)
  2   select substr
  3          ( col
  4          , instr(col,',',1,l) + 1
  5          , instr(col,',',1,l+1) - instr(col,',',1,l) - 1
  6          )
  7     from ( select ',' || col || ',' col from csv_table )
  8        , ( select level l from dual connect by level <= 100 )
  9    where l <= length(col) - length(replace(col,',')) - 1
 10  /

14 rows created.

SQL> select * from normalized_table
  2  /

VALUE
----------
a
a
zz
sd
bb
yy
dfg
ccc

31456
dddd
dasd

sdfsdf

14 rows selected.

सादर, रोब।



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. ORA-00001 अद्वितीय बाधा का उल्लंघन किया गया

  2. SQL डेवलपर स्क्रिप्ट आउटपुट sys_refcursor चौड़ाई को छोटा करता है

  3. ऑरैकल डेटाबेस में दिनांक स्वरूप कैसे बदलें

  4. JSON_TABLE () Oracle में फ़ंक्शन

  5. विशिष्ट उपयोगकर्ता के स्वामित्व वाली सभी तालिकाओं पर अनुदान का चयन करें