org.duracloud.snapshot.sql.snapshot-procedures.sql Maven / Gradle / Ivy
--- Purges data from the spring batch tables that is older than the number
--- of days specified in the days_ago parameter or is associated with a
--- snapshot or restore that has been removed from the system.
--- NOTE: the '#' separators below are there to get around the fact
--- that specifying delimiters in a script do not work with Spring data's
--- DatabasePopulator. c.f. http://stackoverflow.com/questions/15486516/using-springs-jdbcinitialize-database-how-do-i-run-a-script-with-a-stored-p
--- Also note that the "#" delimiter is set in org.duracloud.snapshot.db.DatabaseInitializer.
--- @author Daniel Bernstein
--- @date 01/15/2016
DROP PROCEDURE IF EXISTS purge_obsolete_batch_data#
CREATE PROCEDURE purge_obsolete_batch_data( IN days_ago INT)
BEGIN
set foreign_key_checks=0;
delete from BATCH_JOB_EXECUTION where last_updated < adddate(now(), -1*days_ago) and
status in ('COMPLETED', 'FAILED', 'ABANDONED', 'UNKNOWN');
delete je from BATCH_JOB_EXECUTION je join
(select distinct a.job_execution_id from BATCH_JOB_EXECUTION_PARAMS a,
BATCH_JOB_INSTANCE b,
BATCH_JOB_EXECUTION c
where a.job_execution_id = c.job_execution_id and
b.job_instance_id = c.job_instance_id and
b.job_name = 'snapshot' and
a.string_val not in (select name from snapshot)) je1
on je.job_execution_id = je1.job_execution_id;
delete je from BATCH_JOB_EXECUTION je join
(select a.job_execution_id from BATCH_JOB_EXECUTION_PARAMS a,
BATCH_JOB_INSTANCE b,
BATCH_JOB_EXECUTION c
where a.job_execution_id = c.job_execution_id and
b.job_instance_id = c.job_instance_id and
b.job_name = 'restore' and
a.string_val not in (select restoration_id from restoration)) je1
on je.job_execution_id = je1.job_execution_id;
delete from BATCH_JOB_INSTANCE where job_instance_id not in (select job_instance_id from BATCH_JOB_EXECUTION);
delete from BATCH_JOB_EXECUTION_CONTEXT where job_execution_id not in (select job_execution_id from BATCH_JOB_EXECUTION);
delete from BATCH_JOB_EXECUTION_PARAMS where job_execution_id not in (select job_execution_id from BATCH_JOB_EXECUTION);
delete from BATCH_STEP_EXECUTION where job_execution_id not in (select job_execution_id from BATCH_JOB_EXECUTION);
delete from BATCH_STEP_EXECUTION_CONTEXT where step_execution_id not in (select step_execution_id from BATCH_STEP_EXECUTION);
set foreign_key_checks=1;
END #
© 2015 - 2025 Weber Informatics LLC | Privacy Policy