I'm trying to write some data to a file from oracle using pl/SQL. I seams like the script can only handle very small line sizes. when the linesize gets too big line breakes are added to the file, and I can't figure out why.
Please take a look.
This is my script code:
DECLARE
fHandle UTL_FILE.FILE_TYPE;
filename VARCHAR2(32000) := 'fil';
BEGIN
fHandle := UTL_FILE.FOPEN('dir', filename, 'w');
FOR i IN (SELECT colA, colB, substr(colC,1,20) as colC, colD FROM table)
--FOR i IN (SELECT colA, colB, colC, colD FROM table)
LOOP
utl_file.put_line(fHandle, i.colA||';'||i.ColB||';'||i.colC||';'||i.colD);
END LOOP;
UTL_FILE.FCLOSE(fHandle);
END;
This is the data table:
G100000 1 "AXE DE GUIDAGE D.20h7 LG 700 - POUR DERIVEUR COURSE 500" Obsolete
G200000 2 "AXE DE GUIDAGE D.20h7 LG 700 - POUR DERIVEUR COURSE 500" Released
G300000 1 "*** IDEM D620203-09 *** AIR COMPRESSOR - 1089057554 - PRESS.TRANSDUCER" Obsolete
G400000 1 "*** IDEM D620203-08 *** AIR COMPRESSOR - 1089057470 - TEMPERATURE SENSOR" Obsolete
This is the file output:
G100000;1;AXE DE GUIDAGE D.20h;Obsolete
G200000;2;AXE DE GUIDAGE D.20h;Released
S300000;1;*** IDEM D620203-08 ;Obsolete
S400000;1;*** IDEM D620203-09 ;Obsolete
But if I exchange line 6 with line 7 I get this outcome:
G100000;1;*** IDEM D620203-08 ***
AIR COMPRESSOR - 1089057470 - TEMPERATURE SENSOR;Obsolete
G200000;2;AXE DE GUIDAGE D.20h7 LG 700
- POUR DERIVEUR COURSE 500;Released
G300000;1;*** IDEM D620203-09 ***
AIR COMPRESSOR - 1089057554 - PRESS.TRANSDUCER;Obsolete
G400000;1;AXE DE GUIDAGE D.20h7 LG 700
- POUR DERIVEUR COURSE 500;Obsolete
Any help is very much appreciated.
BR Kresten