drop function if exists staging2.fn_DBSTD_RUN; CREATE OR REPLACE FUNCTION staging2.fn_DBSTD_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='DBSTD' loop select f.file_syspk into w_file_syspk; perform fw_core.fn_get_function_exception('staging2.fn_dbstd_test_block(20,1,''DBSTD'',''DBSTD_TEST'','||w_file_syspk||')'); select e.status from fw_core.db_run_status e where file_syspk = w_file_syspk and file_sheet_mnemonic ='DBSTD_TEST' order by error_timestamp desc into status; if status = 'success' then perform fw_core.fn_get_function_exception('staging2.fn_dbstd_test_trx(20,1,''DBSTD'',''DBSTD_TEST'','||w_file_syspk||')'); end if; end loop; end; $$ LANGUAGE plpgsql;