当前位置:   article > 正文

Oracle定时任务的创建与禁用/删除_oracle删除定时任务

oracle删除定时任务

在开始操作之前,先从三W开始,即我常说的what 是什么;why 为什么使用;how 如何使用。

一、Oracle定时器是什么

Oracle定时器是一种用于在特定时间执行任务或存储过程的工具,可以根据需求设置不同的时间段和频率来执行相应的操作。

二、为什么使用Oracle定时器

使用Oracle定时器的好处在于可以自动化执行重复性的任务,比如每天、每周或每月执行一次数据库维护、数据备份等操作,从而减轻了人工操作的负担,提高了工作效率。

三、如何使用Oracle定时器

使用Oracle定时器的方法包括编写存储过程来定义需要执行的任务,然后创建一个定时器Job来调度这个存储过程。可以根据具体需求设置定时器的执行时间、频率和其他参数,以实现自动化执行任务的目的。

四、目前有哪些主流Oracle定时器?有何区别?

目前主流的Oracle定时器有两种:DBMS_SCHEDULER和DBMS_JOB。它们之间有以下区别:
1. DBMS_SCHEDULER:DBMS_SCHEDULER是Oracle 10g及以上版本引入的定时器。它提供了更强大和灵活的功能,可以创建和管理复杂的作业调度。DBMS_SCHEDULER使用了面向对象的方式来定义作业和调度器,并且支持多种类型的作业,如PL/SQL块、存储过程、外部脚本等。它还支持更多的调度选项,如基于时间、日期、事件等触发器,以及更灵活的重复调度设置。

2. DBMS_JOB:DBMS_JOB是Oracle 9i及以下版本中使用的定时器。它相对简单,只能调度PL/SQL块作业。DBMS_JOB使用了过程式的方式来定义作业和调度器,调度选项相对较少,只能基于时间间隔来触发作业。此外,DBMS_JOB的调度信息存储在数据库中的JOB表中。

总的来说,DBMS_SCHEDULER比DBMS_JOB更强大和灵活,适用于复杂的作业调度需求。而DBMS_JOB则更简单,适用于简单的定时任务。

介绍了概念,接下来是实际使用,参考自蒋老师的文章,感谢蒋老师的分享和归纳——

oracle 定时任务 (yuque.com)icon-default.png?t=N7T8https://www.yuque.com/ernanbei/fh8sgs/fn20rxtaosmfdfnq?singleDoc#最常见的定时场景就是周期性统计动态变化的数据,以我为例,我需要在项目中加入一个Oracel定时器,每三分钟统计一次数据,那首先得写一个函数用于操作数据的读取和存储,其次是设置定时器,通过定时器定时周期性调度执行该函数,从而实现数据的周期性的获取。

1、函数的编写

  1. create PROCEDURE SYNCHRONIZE_HONORING_HISTORY
  2. AS
  3. V_ERR_MSG NVARCHAR2(1000);
  4. V_COUNT_1 NUMBER(1);
  5. V_COUNT_2 NUMBER(5) :=0;
  6. --查询当天的数据
  7. cursor c_job is select APPLY_RECORD_ID,
  8. COMMENDATION_ID,
  9. COMMENDATION_NAME,
  10. USER_NAMES,
  11. UPDATE_DATE,
  12. COMMENDATION_SOURCE,
  13. COMMENDATION_SOURCE_NAME,
  14. COMPETENCE_DIMENSION,
  15. COMPETENCE_DIMENSION_NAME,
  16. SUM_SCORE,
  17. BASE_DEPT_ID
  18. from (select APPLY_RECORD_ID,
  19. COMMENDATION_ID,
  20. COMMENDATION_NAME,
  21. substr(USER_NAME, 0, instr(USER_NAME, ',', -1) - 1) USER_NAMES,
  22. UPDATE_DATE,
  23. COMMENDATION_SOURCE,
  24. COMMENDATION_SOURCE_NAME,
  25. COMPETENCE_DIMENSION,
  26. COMPETENCE_DIMENSION_NAME,
  27. SUM_SCORE,
  28. BASE_DEPT_ID
  29. from (
  30. select A.APPLY_RECORD_ID,
  31. A.COMMENDATION_ID,
  32. C.COMMENDATION_NAME,
  33. xmlagg(xmlelement(e, d.name, ',').extract('//text()')).getclobval() USER_NAME,
  34. A.UPDATE_DATE,
  35. C.COMMENDATION_SOURCE,
  36. E.DICT_VALUE COMMENDATION_SOURCE_NAME,
  37. c.COMPETENCE_DIMENSION,
  38. F.DICT_VALUE COMPETENCE_DIMENSION_NAME,
  39. sum(B.SCORE) SUM_SCORE,
  40. A.BASE_DEPT_ID
  41. from (
  42. select APPLY_RECORD_ID,
  43. COMMENDATION_ID,
  44. UPDATE_DATE,
  45. BASE_DEPT_ID
  46. from DIAN_COMMENDATION_APPLY_RECORD A
  47. where APPLY_STATUS = 'APPROVED'
  48. and UPDATE_DATE >= trunc(sysdate)
  49. and UPDATE_DATE <= trunc(sysdate+ 1)) A
  50. left join (select SOURCE_ID, USER_ID, SCORE,USER_ACCOUNT_ID
  51. from DIAN_COMMENDATION_DISTRIBUTE_RECORD DR
  52. where DR.CREATION_DATE >= trunc(sysdate)
  53. and DR.CREATION_DATE <= trunc(sysdate+ 1)) B
  54. on a.APPLY_RECORD_ID = B.SOURCE_ID
  55. left join DIAN_COMMENDATION C
  56. on A.COMMENDATION_ID = c.COMMENDATION_ID
  57. left join (select A.USER_ID,A.NAME,B.USER_ACCOUNT_ID
  58. from DIAN_USER_EXPAND A
  59. left join DIAN_USER_ACCOUNT b
  60. on a.USER_ID=b.USER_ID
  61. ) D
  62. on B.USER_ID = D.USER_ID
  63. and B.USER_ACCOUNT_ID = D.USER_ACCOUNT_ID
  64. left join (select DICT_VALUE, DICT_KEY
  65. from DIAN_DICTIONARY_MAP
  66. where DICT_TYPE = 'COMMENDATION_SOURCE'
  67. and IS_ENABLE = 1) E
  68. on E.DICT_KEY = c.COMMENDATION_SOURCE
  69. left join (select DICT_VALUE, DICT_KEY
  70. from DIAN_DICTIONARY_MAP
  71. where DICT_TYPE = 'COMPETENCE_DIMENSION'
  72. and IS_ENABLE = 1) F
  73. on F.DICT_KEY = c.COMPETENCE_DIMENSION
  74. group by A.APPLY_RECORD_ID,
  75. A.COMMENDATION_ID,
  76. C.COMMENDATION_NAME,
  77. A.UPDATE_DATE,
  78. C.COMMENDATION_SOURCE,
  79. E.DICT_VALUE,
  80. c.COMPETENCE_DIMENSION,
  81. F.DICT_VALUE,
  82. A.BASE_DEPT_ID
  83. ));
  84. /**
  85. * create by: lcb
  86. * create date:2023-10-30
  87. * modify by:wxx
  88. * modify date:2023-12-8 加入基地ID BASE_DEPT_ID
  89. * describe:同步当天表彰历史数据 (每3分钟同步一次)
  90. */
  91. BEGIN
  92. --循环
  93. FOR ITEM IN C_JOB
  94. LOOP
  95. -- 判断数据是否存在
  96. SELECT COUNT(1) INTO V_COUNT_1 FROM DIAN_HONORING_HISTORY WHERE APPLY_RECORD_ID = ITEM.APPLY_RECORD_ID;
  97. IF V_COUNT_1 = 0 THEN
  98. -- 不存在则添加数据
  99. INSERT INTO DIAN_HONORING_HISTORY(APPLY_RECORD_ID,
  100. COMMENDATION_ID,
  101. COMMENDATION_NAME,
  102. USER_NAMES,
  103. UPDATE_DATE,
  104. COMMENDATION_SOURCE,
  105. COMMENDATION_SOURCE_NAME,
  106. COMPETENCE_DIMENSION,
  107. COMPETENCE_DIMENSION_NAME,
  108. SUM_SCORE,
  109. BASE_DEPT_ID)
  110. VALUES (ITEM.APPLY_RECORD_ID,
  111. ITEM.COMMENDATION_ID,
  112. ITEM.COMMENDATION_NAME,
  113. ITEM.USER_NAMES,
  114. ITEM.UPDATE_DATE,
  115. ITEM.COMMENDATION_SOURCE,
  116. ITEM.COMMENDATION_SOURCE_NAME,
  117. ITEM.COMPETENCE_DIMENSION,
  118. ITEM.COMPETENCE_DIMENSION_NAME,
  119. ITEM.SUM_SCORE,
  120. ITEM.BASE_DEPT_ID);
  121. IF V_COUNT_2 < 100 THEN
  122. V_COUNT_2 := V_COUNT_2 + 1;
  123. ELSE
  124. V_COUNT_2 := 0;
  125. COMMIT;
  126. END IF;
  127. END IF;
  128. END LOOP;
  129. COMMIT;
  130. EXCEPTION
  131. WHEN OTHERS THEN
  132. ROLLBACK;
  133. V_ERR_MSG := SQLERRM || CHR(13) || DBMS_UTILITY.FORMAT_ERROR_BACKTRACE;
  134. JA_WRITE_LOG(JA_UTILS_PKG.GET_FN_NAME(), 'ERROR', V_ERR_MSG, -1, 1);
  135. END;
  136. /

2、设置Oralcle定时器

  1. -- 表彰历史
  2. BEGIN
  3. DBMS_SCHEDULER.CREATE_JOB(
  4. JOB_NAME => 'SYNCHRONIZE_HONORING_HISTORY2',
  5. JOB_TYPE => 'PLSQL_BLOCK',
  6. JOB_ACTION => 'SYNCHRONIZE_HONORING_HISTORY;',
  7. START_DATE => to_date('18-10-2022 00:00:00', 'dd-mm-yyyy hh24:mi:ss'),--开始时间
  8. ENABLED => TRUE, --创建完成后激活
  9. REPEAT_INTERVAL => 'TRUNC(SYSDATE,''MI'')+3/(24*60)', --每3分钟执行一次
  10. -- REPEAT_INTERVAL => 'TRUNC(SYSDATE + 1) + (8*60 + 30)/(24*60)', --每天8:30执行
  11. COMMENTS => '每三分钟统计表彰历史'
  12. );
  13. END;

注意:

如果是第一次使用定时器,需要手动将先前数据同步,如果数据量少可以从开始时间直接同步至当前时间对应数据,但是数据量较大则不建议这么做,会加剧数据库查询和存储的的负担,因此可能需要分时间对其切片,设置开始时间和结束时间并且跨度不宜过大,一点点同步到当前时间,后面就由定时器自动同步就好。

3.定时器的禁用与删除

也会遇到不再使用该定时器的情况,这时候提供了两种操作——禁用或删除。

操作步骤如下:

先查询数据库中的定时任务,查到相关信息如任务名,通过对查询到的任务名执行禁用/删除。

查看当前用户的定时任务指令

  1. --查看当前用户的定时任务
  2. select * from USER_SCHEDULER_JOBS;
-- 测试环境定时任务名
-- SYNCHRONIZE_HONORING_HISTORY_TASK   表彰历史同步
-- SYNCHRONIZE_JINGDIAN_STATISTICS_TASK  表彰项

禁用指令

  1. --禁用
  2. DBMS_SCHEDULER.DISABLE('TEST_JOB'); --暂时停止某个SCHEDULER JOB
--禁用定时任务
begin
DBMS_SCHEDULER.DISABLE('SYNCHRONIZE_HONORING_HISTORY_TASK');
DBMS_SCHEDULER.DISABLE('SYNCHRONIZE_JINGDIAN_STATISTICS_TASK');
end;

删除指令

  1. --删除
  2. DBMS_SCHEDULER.DROP_JOB(JOB_NAME => 'TEST_USER_INSERT',FORCE => TRUE);
-- 删除定时任务
begin
DBMS_SCHEDULER.DROP_JOB(JOB_NAME => 'SYNCHRONIZE_HONORING_HISTORY_TASK',FORCE => TRUE);
DBMS_SCHEDULER.DROP_JOB(JOB_NAME => 'SYNCHRONIZE_JINGDIAN_STATISTICS_TASK',FORCE => TRUE);
end;

这里我用的是禁用,状态可以在查询中查看,再次执行代码

--查看当前用户的定时任务
select * from USER_SCHEDULER_JOBS;

可以看到使用情况变成了False,状态变成了Disabled,应用成功啦!

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/不正经/article/detail/203580?site
推荐阅读
相关标签
  

闽ICP备14008679号