| Oracle FAQ | Your Portal to the Oracle Knowledge Grid | |
|  |  | |||
Home -> Community -> Mailing Lists -> Oracle-L -> Re: Re: read BLOB / insert into table in plsql ?
Hopefully this might help.
Assuming that the BLOB column contains ordinary csv data rather then excel formatted data. e.g just contains the following
1,fred 2,bill 3,george
and also that the length of each row and column is < 4000 bytes the follwing piece of code will strip out the rows and column values.
You should be able to adapt it to suit your needs.
declare
  blob_col   blob;
raw_cr raw(100) := utl_raw.cast_to_raw(chr(10)); csv_line varchar2(4000); col_val varchar2(4000); line_start integer := 1; line_end integer := 1; get_lines boolean := TRUE; x integer := 0; col_start integer := 1; col_end integer := 1; get_cols boolean := TRUE; y integer := 0;
       line_end := dbms_lob.getlength(blob_col)+1;
       get_lines := FALSE;
    line_start := line_end + 1;
    col_start := 1;
    if length(csv_line) > 0 then
       get_cols  := TRUE;
       y := 0;
       while get_cols loop
         y:= y + 1;
         col_end := instr(csv_line,',',col_start);
         if nvl(col_end,0) = 0 then
            col_end := length(csv_line)+1;
            get_cols := FALSE;
         end if;
         col_val := substr(csv_line,col_start,col_end-col_start);
         dbms_output.put_line('Row '||x||'   Column '||y||'   Value
'||col_val);
         col_start := col_end + 1;
       end loop;
      end if;
/
Row 1   Column 1   Value 1
Row 1   Column 2   Value fred
Row 2   Column 1   Value 2
Row 2   Column 2   Value bill
Row 3   Column 1   Value 3
Row 3   Column 2   Value george
For the latest data on the economy and society consult National Statistics at http://www.statistics.gov.uk
-- Archives are at http://www.freelists.org/archives/oracle-l/ FAQ is at http://www.freelists.org/help/fom-serve/cache/1.html -----------------------------------------------------------------Received on Thu Jul 15 2004 - 05:04:38 CDT
|  |  |