视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
通过DBMS_STAT函数关闭执行任务
2020-11-09 15:13:48 责编:小采
文档


过以下语句查看到发生物理读较大的SQL语句 select executions, disk_reads, buffer_gets, round((buffer_g

过以下语句查看到发生物理读较大的SQL语句

select executions,
disk_reads,
buffer_gets,
round((buffer_gets - disk_reads) / buffer_gets, 2) Hit_radio,
round(disk_reads / executions, 2) reads_per_run,
sql_text,
sql_id,
last_load_time
From v$sqlarea
Where executions > 0
and buffer_gets > 0
and (buffer_gets - disk_reads) / buffer_gets < 0.8
and last_load_time > to_date('2015-04-19','yyyy/mm/dd')
Order by 4 desc;

刚好看到该语句磁盘读非常高且执行次数也比较多。

call dbms_stats.gather_database_stats_job_proc ( )

GATHER_DATABASE_STATS_JOB_PROC是内部的存储过程,基本上跟DBMS_STATS.GATHER_DATABASE_STATS的功能一样,但是有内部的优先顺序考虑,更新越多的表将会越优先收集统计信息。
因为该工作消耗较大,,打算关闭,这里就需要用到DBMS_SCHDULER的内建函数,内建函数有如下这些过程调用
......
CREATE_PROGRAM
DROP_PROGRAM
CREATE_JOB
CREATE_SCHEDULE
DROP_SCHEDULE
DISABLE
ENABLE
......

而我们这里需要用到的是通过以下语句来关闭指定的任务
EXEC DBMS_SCHEDULER.DISABLE('GATHER_STATS_JOB');

DISABLE(NAME,FORCE,COMMIT_SEMANTICS)中列出任务名称,是否强制,是否提交,后两者默认为Y
ENBABLE(NAME,COMMIT_SEMANTICS) 相同
而创建任务计划可以通过以下方式
123 DBMS_SCHDULER.CREATE_JOB('job_name', 'job_type', 'job_action', 'number_of_arguments',
'start_date', 'repeat_interval', 'end_date', 'job_class', 'enabled', 'auto_drop',
'comments', 'credential_name', 'destination_name')

列如:
BEGIN
DBMS_SCHEDULER.CREATE_JOB
(
JOB_NAME => 'ARC_MOVE',
SCHEDULE_NAME => 'EVERY_60_MINS',
JOB_TYPE => 'EXECUTABLE',
JOB_ACTION => '/U01/SCRIPTS/MOVE_ARCS.SH',
ENABLED => TRUE,
COMMENTS => 'MOVE ARCHIVED LOGS TO A DIFFERENT DIRECTORY'
);
END;

也可以是
DBMS_SCHDULER.CREATE_SCHEDULE(SCHEDULE_NAME,START_DATE,REPEAT_INTERVAL,END_DATE,COMMENTS)

列如:
BEGIN
DBMS_SCHEDULER.CREATE_SCHEDULE
(
REPEAT_INTERVAL => 'FREQ=MINUTELY;INTERVAL=1',
START_DATE => SYSDATE,
COMMENTS => 'rosanu_create_job',
SCHEDULE_NAME => 'SCHEDULE_ROSANU'
);
END;

其中repeat_interval值得我们注意,这里是提供任务计划的间隔执行时间。
FREQ关键字表示频率,可选参数有:
YEARLY(年),
MONTHLY(月),
WEEKLY(周),
DAILY(日),
HOURLY(时),
MINUTELY(分),
SECONDLY(秒)

INTERVAL关键字表示频数,取值范围1~999。如以下表示每隔10天运行一次:
REPEAT_INTERVAL => 'FREQ=DAILY; INTERVAL=10';

BYDAY关键字表具体某天时间,下列表示每周五执行
REPEAT_INTERVAL => 'FREQ=DAILY; BYDAY=FRI';

BYMONTHDAY关键字表月中的第几天时间,下列表示每月最后一天
REPEAT_INTERVAL => 'FREQ=MONTHLY; BYMONTHDAY=-1';

BYMONTH关键字表示具体的月
REPEAT_INTERVAL => 'FREQ=YEARLY; BYMONTH=MAR; BYMONTHDAY=10';

BYDATE关键字通过数值来指定天数
REPEAT_INTERVAL => 'FREQ=YEARLY; BYDATE=0310';

BYHOUR关键字表示小时
REPEAT_INTERVAL => 'FREQ=DAILY; BYHOUR=16,17,18';

也可以通过该方式指定

REPEAT_INTERVAL => 'trunc(sysdate)+1'
在数据库上通过以下语句查看当前所有的执行任务
SELECT OWNER,
JOB_NAME,
JOB_ACTION,
REPEAT_INTERVAL,
LAST_START_DATE,
COMMENTS
FROM ALL_SCHEDULER_JOBS

除此之外还有DBA_SCHEDULER_JOBS和USER_SCHEDULER_JOBS,USER表没有OWNER字段。

本文永久更新链接地址:

下载本文
显示全文
专题