dbms_jobvsOracleScheduler
在oracle 10g之前,我们常使用DBMS_JOB提供的相关软件包来管理oracle数据库中的定时任务,虽然10g之后,更多推荐功能更强大的DBMS_SCHEDULER,但由于习惯问题,很多时候还是会用到DBMS_JOB,下面简单介绍下两种工作的用法。 DBMS_JOB 1,参数JOB_QUEUE_PROCE
在oracle 10g之前,我们常使用DBMS_JOB提供的相关软件包来管理oracle数据库中的定时任务,虽然10g之后,更多推荐功能更强大的DBMS_SCHEDULER,但由于习惯问题,很多时候还是会用到DBMS_JOB,下面简单介绍下两种工作的用法。
DBMS_JOB
1,参数JOB_QUEUE_PROCESSESoracle已job queue队列的形式管理定时任务,因此需要先设置JOB_QUEUE_PROCESSES参数为非0的数值,一般10即可
ALTER SYSTEM SET JOB_QUEUE_PROCESSES = 10 scope=both;
2, DBMS_JOB用法及例子
SUBMIT:提交任务到队列
VARIABLE jobno NUMBER BEGIN DBMS_JOB.SUBMIT(:jobno, 'DBMS_DDL.ANALYZE_OBJECT(''TABLE'',''SYS'', ''TEST'',''ESTIMATE'', NULL, 50);', SYSDATE, 'SYSDATE + 1'); COMMIT; END; / sys@MS4ADB3(dtydb5)> PRINT jobno JOBNO ---------- 1
查看任务执行情况
sys@MS4ADB3(dtydb5)> select job,what,NEXT_DATE from dba_jobs; JOB WHAT NEXT_DATE ---------- ---------------------------------------------------------------------------------------------------- ------------------- 1 DBMS_DDL.ANALYZE_OBJECT('TABLE','SYS', 'TEST','ESTIMATE', NULL, 50); 2014-04-01 14:16:53
有效job的描述例子如下
'myproc(''10-JAN-99'', next_date, broken);' 'scott.emppackage.give_raise(''JFEE'', 3000.00);' 'dbms_job.remove(job);'
常用的job时间间隔
'SYSDATE + 7' 每隔7天 'SYSDATE + 1/48' 每半个小时 'NEXT_DAY(TRUNC(SYSDATE), ''MONDAY'') + 15/24' 每周一下午三点 'NEXT_DAY(ADD_MONTHS(TRUNC(SYSDATE, ''Q''), 3), ''THURSDAY'')' 每季度的第一个周四
REMOVE
从队列中删除
BEGIN DBMS_JOB.REMOVE(14144); END; /
修改任务的属性
BEGIN DBMS_JOB.CHANGE(14144, NULL, NULL, 'SYSDATE + 3'); END; /
修改任务的描述
BEGIN DBMS_JOB.WHAT(1, 'DBMS_DDL.ANALYZE_OBJECT(''TABLE'',''SYS'', ''T2'',''ESTIMATE'', NULL, 50);'); END; /
任务下一次执行的时间
BEGIN DBMS_JOB.NEXT_DATE(14144, SYSDATE + 4); END; /
任务执行的时间间隔
BROKEN
终止任务的执行
RUN
运行任务
BEGIN DBMS_JOB.RUN(1); END; /
查看job的相关信息,可以查看视图DBA_JOBS和DBA_JOBS_RUNNING
sys@MS4ADB3(dtydb5)> SELECT JOB, NEXT_DATE, NEXT_SEC, FAILURES, BROKEN 2 FROM DBA_JOBS; JOB NEXT_DATE NEXT_SEC FAILURES BR ---------- ------------------- ---------------------------------------------------------------- ---------- -- 1 2014-04-01 14:39:39 14:39:39 0 N
例外,jobs运行失败的日志在alert log里面。
DBMS_SCHEDULER
DBMS_SCHEDULER功能更强大,具有如下优点Logging of job runs (job history) --job运行的日志
Simple but powerful scheduling syntax (similar to but more powerful than cron syntax) --更简单强大的语法
Running of jobs outside of the database on the operating system (see below)--运行os命令
Resource management between different classes of jobs--资源管理功能
Use of job arguments including passing of objects into stored procedures--使用任务参数
Privilege-based security model for jobs -- 更好的权限控制
Naming of jobs and comments in jobs --job命名和描述
Stored, reusable schedules --存储和重用存储过程
--常见用法
BEGIN DBMS_SCHEDULER.create_job ( job_name => 'test_full_job_definition', job_type => 'PLSQL_BLOCK', job_action => 'BEGIN DBMS_STATS.gather_schema_stats(''WJ''); END;', start_date => SYSTIMESTAMP, repeat_interval => 'freq=hourly; byminute=0', end_date => NULL, enabled => TRUE, comments => 'Job defined entirely by the CREATE JOB procedure.'); END;
运行os命令的例子
BEGIN DBMS_SCHEDULER.CREATE_JOB ( job_name => 'my_OS_job', job_type => 'EXECUTABLE', job_action => 'ls /tmp', repeat_interval => 'FREQ=MINUTELY', enabled => TRUE ); END;
--运行一个job
EXEC dbms_scheduler.run_job('TEST_FULL_JOB_DEFINITION'); SELECT * FROM dba_scheduler_jobs WHERE job_name = 'TEST_FULL_JOB_DEFINITION';
REPEAT_INTERVAL的例子
'FREQ=DAILY; BYDAY=SUN; BYHOUR=18;', 'freq=MINUTELY;interval=1', 'freq=MINUTELY;interval=5', 'freq=HOURLY;interval=1', 'FREQ=DAILY; BYDAY=MON,TUE,WED,THU,FRI,SAT,SUN; BYHOUR=22;',
更多关于dbms_scheduler的用法可以常见官方文档
http://docs.oracle.com/cd/E11882_01/server.112/e25494/scheduse.htm#ADMIN13380
参考文档:
http://docs.oracle.com/cd/B10501_01/server.920/a96521/jobq.htm#9499
http://www.mandsconsulting.com/oracle-dbms_scheduler-vs-dbms_job-create-run-monitor-remove
http://docs.oracle.com/cd/E11882_01/server.112/e25494/scheduse.htm#ADMIN13380

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

本文探讨了Docker中的优化MySQL内存使用量。 它讨论了监视技术(Docker统计,性能架构,外部工具)和配置策略。 其中包括Docker内存限制,交换和cgroups

本文介绍了MySQL的“无法打开共享库”错误。 该问题源于MySQL无法找到必要的共享库(.SO/.DLL文件)。解决方案涉及通过系统软件包M验证库安装

本文讨论了使用MySQL的Alter Table语句修改表,包括添加/删除列,重命名表/列以及更改列数据类型。

本文比较使用/不使用PhpMyAdmin的Podman容器直接在Linux上安装MySQL。 它详细介绍了每种方法的安装步骤,强调了Podman在孤立,可移植性和可重复性方面的优势,还

本文提供了SQLite的全面概述,SQLite是一个独立的,无服务器的关系数据库。 它详细介绍了SQLite的优势(简单,可移植性,易用性)和缺点(并发限制,可伸缩性挑战)。 c

本指南展示了使用自制在MacOS上安装和管理多个MySQL版本。 它强调使用自制装置隔离安装,以防止冲突。 本文详细详细介绍了安装,起始/停止服务和最佳PRA

文章讨论了为MySQL配置SSL/TLS加密,包括证书生成和验证。主要问题是使用自签名证书的安全含义。[角色计数:159]

文章讨论了流行的MySQL GUI工具,例如MySQL Workbench和PhpMyAdmin,比较了它们对初学者和高级用户的功能和适合性。[159个字符]
