drop function if exists staging2.fn_IHTBT50_RUN; CREATE OR REPLACE FUNCTION staging2.fn_IHTBT50_RUN() RETURNS void AS $$ declare f record; w_file_syspk int; status text; begin for f in select file_syspk from fw_core.fw_jobctl_file_runschedule where end_status like 'stg1-completed' and file_mnemonic = 'IHTBT50' order by file_syspk loop select f.file_syspk into w_file_syspk; perform fw_core.fn_get_function_exception('staging2.fn_IHTBT50_BT50_Block(20,1,''IHTBT50'',''IHTBT50_BT50'','||w_file_syspk||')'); select e.status from fw_core.db_run_status e where file_syspk = w_file_syspk and file_sheet_mnemonic ='IHTBT50_BT50' order by error_timestamp desc into status; if status = 'success' then perform fw_core.fn_get_function_exception('staging2.fn_IHTBT50_BT50_TRX(20,1,''IHTBT50'',''IHTBT50_BT50'','||w_file_syspk||')'); end if; end loop; end; $$ LANGUAGE plpgsql;