当前位置:   article > 正文

Oracle job常用操作_oracle怎么杀掉job

oracle怎么杀掉job


一、查询job信息

select * from user_jobs;
  • 1

二、查询job是否正在执行

select * from dba_jobs_running where job='job号';
  • 1

三、想要杀job

select b.sid,b.serial# from dba_jobs_running a, v$session b where a.sid=b.sid and a.job='job号';
alter system kill session '会话编号sid,会话序列号serial#';
  • 1
  • 2

补充

  • 如果报错–ORA-00031:标记要终止的会话
    可以通过下列语句查询:
select a.spid,b.sid,b.serial#,b.username
from v$process a,v$session b
where a.addr=b.paddr
and b.status='KILLED';
  • 1
  • 2
  • 3
  • 4

如果利用上面的命令杀死一个进程后,进程状态被置为"killed",但是锁定的资源很长时间没有被释放,那么可以在OS级再杀死相应的进程(线程),首先执行下面的语句获得进程(线程)号:

select b.spid,a.osuser,b.program
from v$session a,v$process b
where a.paddr=b.addr
and a.sid=579     ---579用查询到的sid
  • 1
  • 2
  • 3
  • 4

在OS上杀死这个进程(线程)

用root身份执行命令:

#kill -9 12345(12345 即查询出的进程ID)
  • 1

三、增删改job

先登录到Oracle:

--12c要加@PDB_NAME
--代理登录才能对job进行操作
alter user ZXDB_OB grant connect through dbmon;
connect dbmon[ZXDB_OB]/password;    
  • 1
  • 2
  • 3
  • 4

3.1、新建job

declare
  job number;
BEGIN
  DBMS_JOB.SUBMIT(  
        JOB => job,  /*自动生成JOB_ID*/  
        WHAT => 'proc_add_test;',  /*需要执行的存储过程名称或SQL语句*/  
        NEXT_DATE => sysdate+3/(24*60),  /*初次执行时间-下一个3分钟*/  
        INTERVAL => 'trunc(sysdate,''mi'')+1/(24*60)' /*每隔1分钟执行一次*/
      );  
  commit;
end;
/
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12

3.2、手动执行job


begin
    DBMS_JOB.RUN(40); /*40 job的id*/
end;
/
  • 1
  • 2
  • 3
  • 4
  • 5

3.3、停止job

begin
  dbms_job.broken(v_job,true,next_date);   /*停止一个job,里面参数true也可是false,next_date(某一时刻停止)也可是sysdate(立刻停止)。*/
end;
/
  • 1
  • 2
  • 3
  • 4

3.4、修改job下次运行时间

begin
    dbms_job.next_date(881,to_date('2020-08-19 20:00:00','yyyy-mm-dd hh24:mi:ss'));
    commit;
end;
/
  • 1
  • 2
  • 3
  • 4
  • 5

3.5、修改job运行频率(间隔时间)

begin
    dbms_job.interval(881,'(sysdate+1)+18/24');
    commit;
end;
/
  • 1
  • 2
  • 3
  • 4
  • 5

3.6、修改job要执行的操作

begin
    dbms_job.what(job号,'存储过程名称或者sql语句等');
    commit;
end;
/
  • 1
  • 2
  • 3
  • 4
  • 5

四、其他知识

4.1、存job信息的表user_jobs主要字段说明

列名             数据类型          解释
JOB             NUMBER             任务的唯一标示号
LOG_USER         VARCHAR2(30)     提交任务的用户
PRIV_USER         VARCHAR2(30)     赋予任务权限的用户
SCHEMA_USER     VARCHAR2(30)     对任务作语法分析的用户模式
LAST_DATE         DATE             最后一次成功运行任务的时间
LAST_SEC         VARCHAR2(8)     如HH24:MM:SS格式的last_date日期的小时,分钟和秒
THIS_DATE         DATE              正在运行任务的开始时间,如果没有运行任务则为null
THIS_SEC         VARCHAR2(8)      如HH24:MM:SS格式的this_date日期的小时,分钟和秒
NEXT_DATE         DATE             下一次定时运行任务的时间
NEXT_SEC         VARCHAR2(8)     如HH24:MM:SS格式的next_date日期的小时,分钟和秒
TOTAL_TIME         NUMBER             该任务运行所需要的总时间,单位为秒
BROKEN             VARCHAR2(1)     标志参数,Y标示任务中断,以后不会运行
INTERVAL         VARCHAR2(200)     用于计算下一运行时间的表达式
FAILURES         NUMBER             任务运行连续没有成功的次数
WHAT             VARCHAR2(2000)     执行任务的PL/SQL块
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16

4.2、INTERVAL参数常用值示例

    每天午夜12点            ''TRUNC(SYSDATE + 1)''     
    每天早上8点30分         ''TRUNC(SYSDATE + 1) + (8*60+30)/(24*60)''     
    每星期二中午12点         ''NEXT_DAY(TRUNC(SYSDATE ), ''''TUESDAY'''' ) + 12/24''     
    每个月第一天的午夜12点    ''TRUNC(LAST_DAY(SYSDATE ) + 1)''     
    每个季度最后一天的晚上11点 ''TRUNC(ADD_MONTHS(SYSDATE + 2/24, 3 ), ''Q'' ) -1/24''     
    每星期六和日早上6点10分    ''TRUNC(LEAST(NEXT_DAY(SYSDATE, ''''SATURDAY"), NEXT_DAY(SYSDATE, "SUNDAY"))) + (6×60+10)/(24×60)''    
    每3秒钟执行一次             'sysdate+3/(24*60*60)'   
    每2分钟执行一次           'sysdate+2/(24*60)'   
      
    1:每分钟执行  
    Interval => TRUNC(sysdate,'mi') + 1/ (24*60) --每分钟执行  
    interval => 'sysdate+1/(24*60)'  --每分钟执行  
    interval => 'sysdate+1'    --每天  
    interval => 'sysdate+1/24'   --每小时  
    interval => 'sysdate+2/24*60' --每2分钟  
    interval => 'sysdate+30/24*60*60'  --每30秒  
    2:每天定时执行  
    Interval => TRUNC(sysdate+1)  --每天凌晨0点执行  
    Interval => TRUNC(sysdate+1)+1/24  --每天凌晨1点执行  
    Interval => TRUNC(SYSDATE+1)+(8*60+30)/(24*60)  --每天早上8点30分执行  
    3:每周定时执行  
    Interval => TRUNC(next_day(sysdate,'星期一'))+1/24  --每周一凌晨1点执行  
    Interval => TRUNC(next_day(sysdate,1))+2/24  --每周一凌晨2点执行  
    4:每月定时执行  
    Interval =>TTRUNC(LAST_DAY(SYSDATE)+1)  --每月1日凌晨0点执行  
    Interval =>TRUNC(LAST_DAY(SYSDATE))+1+1/24  --每月1日凌晨1点执行  
    5:每季度定时执行  
    Interval => TRUNC(ADD_MONTHS(SYSDATE,3),'q')  --每季度的第一天凌晨0点执行  
    Interval => TRUNC(ADD_MONTHS(SYSDATE,3),'q') + 1/24  --每季度的第一天凌晨1点执行  
    Interval => TRUNC(ADD_MONTHS(SYSDATE+ 2/24,3),'q')-1/24  --每季度的最后一天的晚上11点执行  
    6:每半年定时执行  
    Interval => ADD_MONTHS(trunc(sysdate,'yyyy'),6)+1/24  --每年7月1日和1月1日凌晨1点  
    7:每年定时执行  
    Interval =>ADD_MONTHS(trunc(sysdate,'yyyy'),12)+1/24  --每年1月1日凌晨1点执行 
  • 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
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/花生_TL007/article/detail/203611
推荐阅读
相关标签
  

闽ICP备14008679号