对于DBA来说,数据库Job再熟悉不过了,因为经常要数据库定时的自动执行一些脚本,或做数据库备份,或做数据的提炼,或做数据库的性能优化,包括重建索引等等的工作。但是,Oracle定时器Job时间的处理上,千变万化,今天我把比较常用写法汇总如下:
在总结之前,先把Job的参数一一说明一下
1.创建job 创建完job后名字显示的是jobno 可用于启动和删除job

declare

job_OpAutoDta pls_integer;
begin
  sys.dbms_job.submit(job =>job_OpAutoDta,  --job参数是由Submit()过程返回的binary_ineger。这个值用来唯一标识一个工作

what => 'wsbs_job_produce_test;',   --what参数是将被执行的PL/SQL代码块,这里过程要带分号 ;

next_date => to_date('04-08-2018 00:01:00', 'dd-mm-yyyy hh24:mi:ss'),--next_date参数指识何时将运行这个工作。写Job的时候可以不指定该值,不指定值的时候创建job会立即执行

interval => 'sysdate+1'); --interval参数何时这个工作将被重执行,其中Interval这个值是决定Job何时,被重新执行的关键

commit;

end;

2.运行job

begin
   dbms_job.run(job_OpAutoDta);--job
end;

3.查询job

--查询所有的job 查询到的job的id 可用来删除job

select * from dba_jobs

--查询正在运行的job

select * from dba_jobs_running

4.删除job

begin
  dbms_job.remove(jobno);  --jobno即查询出来的job id
  commit;
end;

5.常用的日期Interval

Internal参数是一个表示Oracle合法日期表达式的字符串。这个日期字符串的值在每次任务被执行时算出,算出的日期表达式有两种可能,要么是未来的一个时间要么就是null。这里要强调一点:很多开发者都没有意识到next_date是在一个任务开始时算出的,而不是在任务成功完成时算出的。

当任务成功完成时,系统通过更新任务队列目录表将前面算出的next_date值置为下一次任务要运行的时间。当由interval表达式算出next_date是null时,任务自动从任务队列中移出,不会再继续执行。因此,如果传递一个null值给interval参数,则该任务仅仅执行一次。

sysdate+1/24     --这个是间隔一个小时

sysdate+1         --这个是间隔一天

sysdate+7         --这个是间隔一个星期

'TRUNC(SYSDATE + 1)'         每天午夜12点

'TRUNC(SYSDATE + 1) + (8*60+30)/(24*60)'    每星期二中午12点

'TRUNC(LAST_DAY(SYSDATE ) + 1)'     每个月第一天的午夜12点

'TRUNC(ADD_MONTHS(SYSDATE + 2/24, 3 ), 'Q' ) -1/24' 每个季度最后一天的晚上11点

'TRUNC(LEAST(NEXT_DAY(SYSDATE, ''SATURDAY"), NEXT_DAY(SYSDATE, "SUNDAY"))) + (6×60+10)/(24×60)'

6每半年定时执行 如:每年7月1日和1月1日凌晨2点

Interval => ADD_MONTHS(trunc(sysdate,'yyyy'),6)+2/24

6.

  • 8、相关的几个JOB操作
  •  
    删除job:dbms_job.remove(jobno);
  •  
    修改要执行的操作:job:dbms_job.what(jobno,what);
  •  
    修改下次执行时间:dbms_job.next_date(job,next_date);
  •  
    修改间隔时间:dbms_job.interval(job,interval);
  •  
    停止job:dbms.broken(job,broken,nextdate);
  •  
    启动job:dbms_job.run(jobno);
     
    7

    1,查询正在运行的Job,通过查询有两个,和进程占用较多的是两个ORACLE进程符合。
    SQL> SELECT SID,JOB FROM DBA_JOBS_RUNNING;
    SID JOB
    ---------- ----------
    12 116
    16 117
    2,查询正在运行的job的信息
    SQL> SELECT SID,SERIAL# FROM V$SESSION WHERE SID='12';
    SID SERIAL#
    ---------- ----------
    12 4
    SQL> SELECT SID,SERIAL# FROM V$SESSION WHERE SID='16';
    SID SERIAL#
    ---------- ----------
    16 1
    3,利用查询出来的job信息将job结束掉
    SQL> ALTER SYSTEM KILL SESSION '12,4';
    System altered.
    SQL> ALTER SYSTEM KILL SESSION '16,1';
    System altered.
    4,如果不希望运行上述job的话,可以将job设置为broken.
    EXEC DBMS_JOB.BROKEN(116,TRUE);
    EXEC DBMS_JOB.BROKEN(117,TRUE);



 

oracle定时器job的使用的更多相关文章

  1. oracle定时器在项目中的应用

    业务需求: 现在业务人员提出了一个需求: 在项目中的工作流,都要有一个流程编号,此编号有一定的规则: 前四五位是流程的字母缩写,中间是8位的日期,后面五位是流水码,要求流水码每天从00001开始.即: ...

  2. oracle 定时器调用存储过程

    转载请说明出处:http://t22011787.iteye.com/blog/1112745 一.查询系统中的job,可以查询视图 --相关视图 select * from dba_jobs; se ...

  3. oracle定时器,调用存储过程,定时从n张表中取值新增到本地一张表中

    --创建新增本地数据库的存储过程create or replaceprocedure pro_electric_record as  begin    insert into electric_met ...

  4. Oracle定时器调用存储过程

    1. 创建表 create table job_table(run_time date); 2. 创建存储过程 create or replace procedure job_proc is begi ...

  5. Oracle 定时器

    我的代码 declare job number; begin dbms_job.submit( JOB=>job, what=>'addBytime;',// 这里要写分号,不然容易出错. ...

  6. oracle定时器

    /* 每10秒钟执行一次 插入一条时间 */ -- 创建table create table tab_time( current_time timestamp ); -- 创建存储过程 create ...

  7. Oracle定时器执行多线程

    what里面加下面代码强制执行多线程   begin  execute immediate 'alter session force parallel dml parallel 16';  pkg_s ...

  8. oracle定时器执行一遍就不执行或本就不执行

    转:http://blog.csdn.net/qq_23311211/article/details/76283689 以sqlplus/ assysdba进入sql命令模式,使用sql:select ...

  9. oracle中job定时器任务

    对于DBA来说,经常要数据库定时的自动执行一些脚本,或做数据库备份,或做数据的提炼,或做数据库的性能优化,包括重建索引等等的工作.但是,Oracle定时器Job时间的处理上,千变万化,今天我把比较常用 ...

随机推荐

  1. Memcache命令及参数用法

    Memcache命令:在linux下: # /usr/local/bin/memcached -d -m 128 -u root -l 192.168.0.10 -p 12121 -c 256 -P ...

  2. 【Android N 7】使用量统计usagestats

    Android N 7.1.1 高通 1. /data/system/usagestats/0 2. 每天使用量统计 /data/system/usagestats/0/daily 查看数值: cat ...

  3. POJ1125-Stockbroker Grapevine Floyd算法多源最短路径

    这题的思路还是比较简单,用弗洛伊德算法打表后,枚举来找到最小值 代码如下 注意最后判断时候的语句 在这里错误了很多次 # include<iostream> # include<al ...

  4. Mac下Python与Kafka的配合使用

    安装并配置Kafka 安装 # brew install kafka 配置 """ zookeeper配置文件/usr/local/etc/kafka/zookeeper ...

  5. BluePrint和ORM

    一.蓝图创建 #引入库文件 from flask import Blueprint,request,jsonify user = Blueprint( "site", __name ...

  6. 【Wannafly挑战赛4】F 线路规划 倍增+Kruskal+归并

    [Wannafly挑战赛4]F 线路规划 题目描述 Q国的监察院是一个神秘的组织.这个组织掌握了整个帝国的地下力量,监察着Q国的每一个人.监察院一共有N个成员,每一个成员都有且仅有1个直接上司,而他只 ...

  7. 证书:数字签名和验签&加密和解密

    用的是湖北省数字证书认证管理中心的签名和加密 1.带私钥的证书,即p12格式证书(后缀为.pfx) 2.不带私钥的证书,有多种格式,通常我们使用的是cer格式证书(后缀为.cer) 一. 1.什么是对 ...

  8. mysql 远程连接超时解决办法

    设置mysql远程连接root权限 在远程连接mysql的时候应该都碰到过,root用户无法远程连接mysql,只可以本地连,对外拒绝连接. 需要建立一个允许远程登录的数据库帐户,这样才可以进行在远程 ...

  9. 【数组】—冒泡排序&&选择排序---【巷子】

    /* 什么是冒泡排序:从头到尾比较相邻的两个数的大小,如果符合条件则进行比较 [注]:从小到大进行排序 假设有一个数组 var arr = [9,8,7,6,5,4]; 我们想要进行这个数组进行排序那 ...

  10. debug kibana in chrome

    kibana5.6.5版本 在kibana根目录运行命令:NODE_OPTIONS='--inspect --debug' npm start 也可以尝试命令:NODE_OPTIONS="- ...