forked from gwenshap/Oracle-DBA-Scripts
-
Notifications
You must be signed in to change notification settings - Fork 9
/
Copy pathjob_scheduling.sql
128 lines (105 loc) · 3.66 KB
/
job_scheduling.sql
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
-- Decent reference for new scheduler
http://www.oradev.com/dbms_scheduler.jsp
-- view job and schedule (new)
select owner,job_name,job_action,program_name,repeat_interval, state,failure_count,
LAST_START_DATE,LAST_RUN_DURATION,NEXT_RUN_DATE,
JOB_CLASS ,schedule_name,schedule_owner
from dba_scheduler_jobs where owner='AVAIL';
where job_name like 'myjob%';
-- view job and schedule (old)
select job,what,to_char(last_date,'dd-mm-yyyy hh24:mi'),to_char(next_date,'dd-mm-yyyy hh24:mi'),interval,failures,broken from dba_jobs;
-- all scheduler windows
set pagesize 300 linesize 200
select * from dba_scheduler_windows
-- All schedules
select schedule_name, schedule_type, start_date, repeat_interval from dba_scheduler_schedules
-- currently running jobs (old)
SELECT
dba_jobs.JOB,
instance,
SCHEMA_USER,
LAST_DATE,
NEXT_DATE,
interval,
BROKEN,
FAILURES,
RUNNING,
SID,
what
FROM DBA_JOBS
LEFT OUTER JOIN (SELECT
JOB,'YES' RUNNING,SID
FROM DBA_JOBS_RUNNING ) running
ON DBA_JOBS.JOB = RUNNING.JOB
ORDER BY SCHEMA_USER, last_date;
-- currently running jobs (new)
select * from dba_scheduler_running_jobs;
--history for job
select job_name,status,req_start_date,actual_start_date,run_duration from DBA_SCHEDULER_JOB_RUN_DETAILS where job_name like 'REFRESH_BSP_COMP_MVIEWS%' and req_start_date> sysdate-3 order by req_start_date;
select log_date
, job_name
, status
from dba_scheduler_job_log where ;
-- job control
exec dbms_scheduler.stop_job('owner.job');
exec dbms_scheduler.enable('owner.job');
DECLARE
exist_flag number(1):=0;
err_msg varchar2(200);
BEGIN
--Create hourly schedule
exist_flag:=0;
select count(*) into exist_flag
from dba_scheduler_schedules
where schedule_name='HOURLY_STATISTICS';
IF exist_flag=0 THEN
sys.dbms_scheduler.create_schedule(
repeat_interval => 'FREQ=HOURLY',
start_date => systimestamp,
comments => 'Collect statistics each hour',
schedule_name => '"SYSTEM"."HOURLY_STATISTICS"');
END IF;
dbms_output.put_line('Succeeded to create new schedules');
EXCEPTION
when others then
err_msg:=substr(sqlerrm,1,200);
dbms_output.put_line('Error during definition of new schedule '||err_msg);
END;
DECLARE
exist_flag number(1):=0;
err_msg varchar2(200);
BEGIN
--Create a job scheduled to run each hour in CMDB schema for collecting statistics in "gather auto"
select count(*)
into exist_flag
from dba_scheduler_jobs
where job_name='HOURLY_REFRESH_CMDB_STATS';
IF exist_flag=0 THEN
sys.dbms_scheduler.create_job(
job_name => '"SYSTEM"."HOURLY_REFRESH_CMDB_STATS"',
job_type => 'PLSQL_BLOCK',
job_action => 'begin
DBMS_STATS.GATHER_SCHEMA_STATS(''&cmdb_schema'',OPTIONS=>''GATHER AUTO'');
end;',
schedule_name => 'SYSTEM.HOURLY_STATISTICS',
job_class => 'DEFAULT_JOB_CLASS',
comments => 'CMDB missing statistics refresh by the hour',
auto_drop => FALSE,
enabled => TRUE);
END IF;
dbms_output.put_line('Succeeded to define hourly statistics job');
EXCEPTION
when others then
err_msg:=substr(sqlerrm,1,200);
dbms_output.put_line('Error during job creation '||err_msg);
END;
-- job defined entirely in "create job"
exec DBMS_SCHEDULER.create_job (
job_name => 'strmadmin.Streams_HeartBeat',
job_type => 'PLSQL_BLOCK',
job_action => 'begin update strmadmin.prod2_heartbeat set DB_CHANGE_TIME=sysdate where db_name=''PROD2''; commit; end;',
start_date => SYSTIMESTAMP,
repeat_interval => 'freq=MINUTELY; interval=10',
end_date => NULL,
enabled => TRUE,
comments => 'Generate streams heartbeat every 10 minutes');