工作中可能遇到这样的情况,在A用户下有一个不用的job,但是dba不知道A用户的密码,怎么删除这个job呢。
 
相信大部分人都会尝试在sys用户下用dbms_job.remove()命令去删除它,但是会报错
sys用户下
SQL> exec dbms_job.remove(70);
BEGIN dbms_job.remove(70); END;
 
*
ERROR at line 1:
ORA-23421: job number 70 is not a job in the job queue
ORA-06512: at "SYS.DBMS_SYS_ERROR", line 86
ORA-06512: at "SYS.DBMS_IJOB", line 680
ORA-06512: at "SYS.DBMS_JOB", line 174
ORA-06512: at line 1
 
 
还是在sys用户下,使用dbms_ijob.remove()就可以删除
SQL>  exec dbms_ijob.remove(70);
 
PL/SQL procedure successfully completed.
 
 
那么,到底dbms_job和dbms_ijob到底怎么用,彼此有什么区别呢?下面用实验证明。
 
一、sys用户使用dbms_ijob为hou用户创建job
1.查看dbms_ijob.submit的书写格式
 
sys用户下desc dbms_ijob
 
PROCEDURE SUBMIT
Argument Name               Type               In/Out Default?
------------------------------ ----------------------- ------ --------
JOB                    BINARY_INTEGER          IN
LUSER                    VARCHAR2          IN    -->     Login user when the job was submitted
PUSER                    VARCHAR2          IN    -->   User whose default privileges apply to this job
CUSER                    VARCHAR2          IN    -->   schema_user
NEXT_DATE               DATE               IN
INTERVAL               VARCHAR2          IN
BROKEN                BOOLEAN           IN
WHAT                    VARCHAR2          IN    -->procedure
NLSENV                VARCHAR2          IN
ENV                    RAW               IN
 
 
2.hou用户下创建一个简单存储过程
SQL> conn hou/  
Enter password:
Connected.
SQL>  create table test(a date);
 
Table created.
 
SQL> create or replace procedure pro_insert_date as
begin
insert into test values(sysdate);
end;
/  2    3    4    5 
 
Procedure created.
 
 
3.sys用户为hou创建5号job
SQL> conn / as sysdba
Connected.
SQL> begin
dbms_ijob.submit(5,'HOU','HOU','HOU',
to_date('2012-09-29 12:30:00','YYYY-MM-DD HH24:MI:SS'),'sysdate+1',false,'pro_insert_date;',
'NLS_LANGUAGE=''SIMPLIFIED CHINESE'' NLS_TERRITORY=''CHINA'' NLS_CURRENCY=''¥'' NLS_ISO_CURRENCY=''CHINA'' NLS_NUMERIC_CHARACTERS=''.,'' NLS_DATE_FORMAT=''yyyy-mm-dd hh24:mi:ss'' NLS_DATE_LANGUAGE=''SIMPLIFIED CHINESE'' NLS_SORT=''BINARY''',
'0102000200000000');
commit;
end;
/
匿名块已完成
 
 
或者写成
begin
dbms_ijob.submit(5,'HOU','HOU','HOU',
to_date('2012-09-29 12:30:00','YYYY-MM-DD HH24:MI:SS'),'sysdate+1',false,'pro_insert_date;',
'NLS_LANGUAGE=''SIMPLIFIED CHINESE'' NLS_TERRITORY=''CHINA'' '||
'NLS_CURRENCY=''¥'' NLS_ISO_CURRENCY=''CHINA'' '||
'NLS_NUMERIC_CHARACTERS=''.,'' '||
'NLS_DATE_FORMAT=''YYYY-MM-DD HH24:MI:SS'' '||
'NLS_DATE_LANGUAGE=''SIMPLIFIED CHINESE'' NLS_SORT=''BINARY'' ',
'0102000200000000');
commit;
end;
/
 
 
 
注意:1.dbms_ijob.submit创建job时,只能手动指定job号。
      2.书写顺序要按照上面的顺序。
      3.用户名一定要大写。
 
注意:上面两条写法是在sql developer中能够执行成功。在sqlplus下无法执行成功,由于涉及到中文货币符号,在这里也就是NLS_CURRENCY=''¥''。
想要在sqlplus下执行成功,将¥换成$即可。至于如何能够在sqlplus下使用中文货币符号,还需要再研究。
 
 
 
4.登录到hou用户查看5号job的情况
SQL> conn hou/
Enter password:
Connected.
SQL> select job,what,LOG_USER,PRIV_USER,SCHEMA_USER,to_char(last_date,'YYYY-MM-DD HH24:MI:SS'),to_char(next_date,'YYYY-MM-DD HH24:MI:SS'),interval,broken,failures from user_jobs;
 
       JOB WHAT                  LOG_USER   PRIV_USER     SCHEMA_USE TO_CHAR(LAST_DATE,' TO_CHAR(NEXT_DATE,' INTERVAL          B   FAILURES
---------- ------------------------------ ---------- ---------- ---------- ------------------- ------------------- -------------------- - ----------
     5 pro_insert_date;            HOU          HOU     HOU        2012-09-29 14:42:14 2012-09-30 14:42:14 sysdate+1          N        0
 
 
 
可以看到,sys用户通过dbms_ijob已经为hou用户创建了job。
 
 
二、执行5号job
1.在hou用户下
SQL> conn hou
Enter password:
Connected.
SQL> exec dbms_job.run(5);
 
PL/SQL procedure successfully completed.
 
2.在sys用户下执行
SQL> conn / as sysdba
Connected.
SQL> exec dbms_ijob.run(5);
 
PL/SQL procedure successfully completed.
 
 
sys通过dbms_ijob.submit为其他用户创建的job,sys和job所在的用户都可以执行。
 
 
 
三、修改job
1.hou用户修改job的执行间隔时间(interval)和下次执行时间(next_day)
SQL> exec dbms_job.interval(5,'sysdate+2');
 
PL/SQL procedure successfully completed.
 
查看job情况
SQL>  select job,what,LOG_USER,PRIV_USER,SCHEMA_USER,to_char(last_date,'YYYY-MM-DD HH24:MI:SS'),to_char(next_date,'YYYY-MM-DD HH24:MI:SS'),interval,broken,failures from user_jobs;
 
       JOB WHAT                  LOG_USER   PRIV_USER     SCHEMA_USE TO_CHAR(LAST_DATE,' TO_CHAR(NEXT_DATE,' INTERVAL          B   FAILURES
---------- ------------------------------ ---------- ---------- ---------- ------------------- ------------------- -------------------- - ----------
     5 pro_insert_date;            HOU          HOU     HOU        2012-09-29 14:45:50 2012-09-30 14:45:50 sysdate+2          N        0
 
 
修改next_day
SQL> exec dbms_job.next_date(5,sysdate+1/24);
 
PL/SQL procedure successfully completed.
 
SQL> commit;
 
Commit complete.
 
 
 
 
 
2.sys用户
SQL> exec dbms_ijob.interval(5,'sysdate+2');
 
PL/SQL procedure successfully completed.
 
SQL> commit;
 
Commit complete.
 
 
修改next_day
SQL>  exec dbms_ijob.next_date(5,sysdate+5);
 
PL/SQL procedure successfully completed.
 
SQL> commit;
 
Commit complete.
 
 
 
四.中断job
1.hou用户
SQL> exec dbms_job.broken(5,true);
 
PL/SQL procedure successfully completed.
 
SQL> commit;
 
Commit complete.
 
SQL>
SQL>  select job,what,LOG_USER,PRIV_USER,SCHEMA_USER,to_char(last_date,'YYYY-MM-DD HH24:MI:SS'),to_char(next_date,'YYYY-MM-DD HH24:MI:SS'),interval,broken,failures from user_jobs;
 
       JOB WHAT                  LOG_USER   PRIV_USER     SCHEMA_USE TO_CHAR(LAST_DATE,' TO_CHAR(NEXT_DATE,' INTERVAL          B   FAILURES
---------- ------------------------------ ---------- ---------- ---------- ------------------- ------------------- -------------------- - ----------
     5 pro_insert_date;            HOU          HOU     HOU        2012-09-29 14:45:50 4000-01-01 00:00:00 sysdate+2          Y        0
 
 
2.sys用户
SQL> exec dbms_ijob.broken(5,true);
 
PL/SQL procedure successfully completed.
 
SQL> commit;
 
Commit complete.
 
SQL> conn hou
Enter password:
Connected.
SQL>  select job,what,LOG_USER,PRIV_USER,SCHEMA_USER,to_char(last_date,'YYYY-MM-DD HH24:MI:SS'),to_char(next_date,'YYYY-MM-DD HH24:MI:SS'),interval,broken,failures from user_jobs;
 
       JOB WHAT                  LOG_USER   PRIV_USER     SCHEMA_USE TO_CHAR(LAST_DATE,' TO_CHAR(NEXT_DATE,' INTERVAL          B   FAILURES
---------- ------------------------------ ---------- ---------- ---------- ------------------- ------------------- -------------------- - ----------
     5 pro_insert_date;            HOU          HOU     HOU        2012-09-29 14:45:50 4000-01-01 00:00:00 sysdate+2          Y        0
 
 
五.删除job
1.hou用户
SQL> exec dbms_job.remove(5);
 
PL/SQL procedure successfully completed.
 
SQL> select job,what,LOG_USER,PRIV_USER,SCHEMA_USER,to_char(last_date,'YYYY-MM-DD HH24:MI:SS'),to_char(next_date,'YYYY-MM-DD HH24:MI:SS'),interval,broken,failures from user_jobs;
 
no rows selected
 
 
2.sys用户
SQL> exec dbms_ijob.remove(5);
 
PL/SQL procedure successfully completed.
 
SQL> commit;
 
Commit complete.
 
 
SQL> conn hou
Enter password:
Connected.
SQL> select job,what,LOG_USER,PRIV_USER,SCHEMA_USER,to_char(last_date,'YYYY-MM-DD HH24:MI:SS'),to_char(next_date,'YYYY-MM-DD HH24:MI:SS'),interval,broken,failures from user_jobs;
 
no rows selected
 
 
 
总结:
1.dbms_job只能在当期用户内创建job、修改和删除job,不能对其他用户的job进行操作;sys用户也无法用dbms_job管理其他用户的job。
2.dbms_ijob只能由sys用户去执行,拥有DBA权限的用户都没有权限去执行它。
3.通过dbms_ijob sys用户可以给其他用户创建job,且job在该用户下,在该用户内可以通过user_jobs视图看到。
4.通过dbms_ijob sys用户能够对其他用户中的job进行删除、修改。
5.sys用户通过dbms_ijob给X用户创建job,那么X用户对该job拥有修改和删除的权限。
 
 
dbms_ijob书写格式:
1.创建job
begin
dbms_ijob.submit(jobnu,' LUSER  ',' PUSER ',' CUSER ',
next day,'interval',false,'procedure_name;',
'NLS_LANGUAGE=''SIMPLIFIED CHINESE'' NLS_TERRITORY=''CHINA'' '||
'NLS_CURRENCY=''¥'' NLS_ISO_CURRENCY=''CHINA'' '||
'NLS_NUMERIC_CHARACTERS=''.,'' '||
'NLS_DATE_FORMAT=''YYYY-MM-DD HH24:MI:SS'' '||
'NLS_DATE_LANGUAGE=''SIMPLIFIED CHINESE'' NLS_SORT=''BINARY'' ',
'0102000200000000');
commit;
end;
/
 
2.执行job
exec dbms_ijob.run(jobnumber);
 
3.修改job的间隔时间(interval)
 exec dbms_ijob.interval(5,'sysdate+2');
 
4.修改job的下次执行时间
 exec dbms_ijob.next_date(5,sysdate+5);
 
5.中断job
exec dbms_ijob.broken(5,true);
 
6.删除job
exec dbms_ijob.remove(5); 

dbms_job和dbmsi_job的更多相关文章

  1. oracle dbms_JOB

    添加一个任务,怎么老是报错 [SQL] DECLARE job1 number; begin dbms_job.submit(job1,'RESTUDY_SCORE_IMPORT',sysdate,' ...

  2. dbms_job.submit 单次执行

    DBMS_JOB.SUBMIT用于定时任务,基本用法如下: DBMS_JOB.SUBMIT(:jobno,//job号                                      'yo ...

  3. ORACLE数据库DBMS_JOB的创建与使用

    http://my.oschina.net/u/2309120/blog/371437 创建 DBMS_JOB 使用以下语句: VARIABLE jobno number;begin DBMS_JOB ...

  4. oracle 定时任务(DBMS_JOB)

    示例如下: -- 每隔一分钟执行存储过程p1 create or replace procedure p2 as job_num number; begin dbms_job.submit(job_n ...

  5. DBMS_SCHEDULER and DBMS_JOB

    引用原文:http://foolraty.iteye.com/blog/1107803 For DBMS_JOB usage:To find out more information about th ...

  6. dbms_job涉及到的知识点

    用于安排和管理作业队列,通过使用作业,可以使ORACLE数据库定期执行特定的任务. 一.dbms_job涉及到的知识点1.创建job:variable jobno number;dbms_job.su ...

  7. dbms_job dbms_scheduler简单比较

    ---------------------------陈旧的-------------------------------------/*--------------------- 创建job --- ...

  8. 关于oracle dbms_job 定时执行的内容。

    一.设置初始化参数 job_queue_processessql> alter system set job_queue_processes=n;(n>0)job_queue_proces ...

  9. 踩坑系列の Oracle dbms_job简单使用

    二话不说先上代码 --创建存储过程 create or replace procedure job_truncateState is begin --此处就是要定时执行的sql execute imm ...

随机推荐

  1. [Buffalo] 一些SQL函数

    取得当前时间的函数:GETDATE() 计算时间的函数:DATEADD(datepart,number,date) 计算两个时间差额:DATEDIFF(datepart,startdate,endda ...

  2. lua package.path的使用

    需要用lua写一个工具,c++调用lua,然后这个lua要require其他lua脚本,在主lua里面设置package.path,但一直都失败,甚至lua都无法编译通过. project_path ...

  3. 2014-5-23 s3c2440到手

    ( 之前的开发板是s5pv210  (contex  A8)); 现在入手JZ2440......................

  4. Java笔记(十五)……面向对象IV多态(polymorphism)

    概述 定义:某一类事物的多种存在形态. 例:动物中猫,狗. 猫这个对象对应的类型是猫类型 猫 x = new 猫(); 同时猫也是动物中的一种,也可以把猫称为动物. 动物 y = new 猫(); 动 ...

  5. 实用Yii扩展

    可以去官方搜索Yii扩展:Extensions | Yii PHP Framework http://www.yiiframework.com/extensions/?tag=tree Yii che ...

  6. Asp.net多行文本框随内容增加而高度增加

    最近做一个项目,在一个多行文本框(TextBox)里显示新闻内容,由于内容有多有少,并且总是出现垂直滚动条,很不好看,笔者就想用一个法子,去掉垂直滚动条,并且文本框的高度随内容的增加而变大,使高度适应 ...

  7. epoll原理解释(转)

    转自:http://yaocoder.blog.51cto.com/2668309/888374   首先我们来定义流的概念,一个流可以是文件,socket,pipe等等可以进行I/O操作的内核对象. ...

  8. javascript获取元素的计算样式

    使用css控制页面有4种方式,分别为行内样式(内联样式).内嵌式.链接式.导入式. 行内样式(内联样式)即写在html标签中的style属性中,如<div style="width:1 ...

  9. eclipse调试的基本意义

    step into就是单步执行,遇到子函数就进入并且继续单步执行: step over是在单步执行时,在函数内遇到子函数时不会进入子函数内单步执行,而是将子函数整个执行完再停止,也就是把子函数整个作为 ...

  10. iOS开发 落地消息多的处理办法(仅供参考)

    1.首先要知道一点,你的消息储存是用数据库储存的! 看了一下微信和qq的消息处理,一般情况下第三方(亲加,容云,环信都会有本地的数据库)处理过的! 但是我发现,最近一个需求要求开发@"消息已 ...