WHENEVER SQLERROR EXIT SQL.SQLCODE

-- Disable statspack job.
BEGIN
  FOR i in (select job from user_jobs where lower(what) like '%snap%' )
  LOOP
    sys.dbms_job.broken(i.job,TRUE);
  END LOOP;    
  COMMIT;  
END;
/

-- Export Statspack schema
host expdp directory=export_dump schemas=PERFSTAT dumpfile=PERFSTAT.dmp logfile=PERFSTAT.log

-- Disable all  constraints
BEGIN
  FOR i in (select 'ALTER TABLE ' || OWNER || '.' || TABLE_NAME 
                   || ' MODIFY CONSTRAINT ' || CONSTRAINT_NAME 
                   || ' DISABLE'  sqltext
            from dba_constraints 
            where owner = 'PERFSTAT'
            and status <> 'DISABLED'
             and  constraint_type = 'R')
  LOOP
      execute immediate i.sqltext;
  END LOOP;
  FOR i in (select 'ALTER TABLE ' || OWNER || '.' || TABLE_NAME 
                   || ' MODIFY CONSTRAINT ' || CONSTRAINT_NAME 
                   || ' DISABLE'  sqltext
            from dba_constraints 
            where owner = 'PERFSTAT'
            and status <> 'DISABLED')
  LOOP
      execute immediate i.sqltext;
  END LOOP;
END;
/

-- Truncate All tables
BEGIN
  FOR i in (select 'TRUNCATE TABLE ' || OWNER || '.' || TABLE_NAME sqltext
            from   dba_tables where owner = 'PERFSTAT')
  LOOP
      execute immediate i.sqltext;
  END LOOP;
END;
/

-- Import Statspack schema
host impdp directory=export_dump schemas=PERFSTAT content=data_only dumpfile=PERFSTAT.dmp logfile=PERFSTAT.log


-- Enable all  constraints
BEGIN
  FOR i in (select 'ALTER TABLE ' || OWNER || '.' || TABLE_NAME 
                   || ' MODIFY CONSTRAINT ' || CONSTRAINT_NAME 
                   || ' ENABLE'  sqltext
            from dba_constraints 
            where owner = 'PERFSTAT'
             AND constraint_type IN ('P','U')
             and status = 'DISABLED'
            )
  LOOP
      execute immediate i.sqltext;
  END LOOP;
  FOR i in (select 'ALTER TABLE ' || OWNER || '.' || TABLE_NAME 
                   || ' MODIFY CONSTRAINT ' || CONSTRAINT_NAME 
                   || ' ENABLE'  sqltext
            from dba_constraints where owner = 'PERFSTAT'
            and status = 'DISABLED')
  LOOP
      execute immediate i.sqltext;
  END LOOP;
END;
/


-- Enable statspack job.
BEGIN
  FOR i in (select job from user_jobs where lower(what) like '%snap%' )
  LOOP
    sys.dbms_job.broken(i.job,FALSE);
  END LOOP;    
  COMMIT;  
END;
/
