ループの出力をファイルにスプールする必要があります。そのための私のコードは次のとおりです。
set termout off
set echo off
set colsep ''
set linesize 5000
set heading off
set feedback off
set preformat off
set trimspool on
set serverout on
spool 'C:\folder\script.sql'
begin
for rec in (select unique prgm_id from tmp_table_output) loop
for rec2 in (select unique cmpg_id from tmp_table_output where prgm_id = rec.prgm_id) loop
dbms_output.put_line('spool ''C:\folder\PRG''||lpad('||rec.prgm_id||', 4, 0)||''_CMPG''||lpad('||rec2.cmpg_id||', 4, 0)||''.txt'' CREATE');
dbms_output.put_line('SELECT field FROM tmp_table_output where prgm_id = '||rec.prgm_id||' and cmpg_id = '||rec2.cmpg_id);
dbms_output.put_line('spool off');
end loop;
end loop;
end;
/
spool off;
ただし、実際にループを反復するのではなく、script.sql ファイルを確認すると、出力は次のようになります。
begin
for rec in (select unique prgm_id from tmp_table_output) loop
for rec2 in (select unique cmpg_id from tmp_table_output where prgm_id = rec.prgm_id) loop
dbms_output.put_line('spool ''C:\RemoteOnboarding\PRG''||lpad('||rec.prgm_id||', 4, 0)||''_CMPG''||lpad('||rec2.cmpg_id||', 4, 0)||''.txt'' CREATE');
dbms_output.put_line('SELECT field FROM tmp_unica_output where prgm_id = '||rec.prgm_id||' and cmpg_id = '||rec2.cmpg_id);
dbms_output.put_line('spool off');
end loop;
end loop;
end;
/
spool off;
ループ出力をファイルに書き込むにはどうすればよいですか?