 
                        
        
                        
        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