Oracle定时任务Job笔记

时间:2023-02-26 20:43:05

定时任务应用场景:

  某一个生产系统上面,临时表不断变多,占了不少磁盘空间。由于这套软件是直接买的,不方便修改源代码。所以考虑使用Oracle定时任务直接从数据库层删除临时表。

定时任务业务:

  首先写好一个存储过程。读当前用户所有以tempXXXXX开头的临时表,然后依次删除所有的临时表。然后在建立Oracle Job每天晚上定时调用这个存储过程。

存储过程代码:

create or replace PROCEDURE KDDROPTEMPTABLE AS
BEGIN
  declare
  cursor c_usertable is
  select table_name from user_tables t where t.TABLE_NAME like 'TEMPTABLE0000%' and status = 'VALID';
  my_tablename user_tables.table_name%TYPE;
  v_sql varchar2(200);
  v_count integer := 0;
  begin
    --DBMS_OUTPUT.ENABLE(buffer_size => null);
       open c_usertable;
         loop
           --提取一行数据到c_usertable
           fetch c_usertable into my_tablename;
           exit when c_usertable%notfound;
           v_sql := 'drop table '||my_tablename;
           execute immediate v_sql;
           v_count := v_count+1;
           -- dbms_output.put_line(v_sql);
         end loop;
       --关闭游标
      close c_usertable;
      dbms_output.put_line('总工删除的临时表数量:'||v_count);
  end;
END KDDROPTEMPTABLE;

Oracle定时任务建立步骤

Oracle有两种语法可以建定时任务,Oracle10g以后就开始推荐使用下面这种。老的方式本文不涉及。

如果你有Oracle SQL developer可以用界面新建

Oracle定时任务Job笔记

Oracle定时任务Job笔记

Oracle定时任务Job笔记

Oracle定时任务Job笔记

以下是通过SQL直接建Job:

BEGIN
    DBMS_SCHEDULER.CREATE_JOB (
            job_name => '"ZSNC57"."autoDeleteTemp"',
            job_type => 'STORED_PROCEDURE',
            job_action => 'ZSNC57.KDDROPTEMPTABLE',
            number_of_arguments => 0,
            start_date => TO_TIMESTAMP_TZ('2018-09-12 14:41:09.000000000 ASIA/SHANGHAI','YYYY-MM-DD HH24:MI:SS.FF TZR'),
            repeat_interval => 'FREQ=DAILY;BYHOUR=14;BYMINUTE=45;BYSECOND=0',
            end_date => NULL,
            enabled => FALSE,
            auto_drop => TRUE,
            comments => '自动删除临时表');

DBMS_SCHEDULER.SET_ATTRIBUTE(
             name => '"ZSNC57"."autoDeleteTemp"',
             attribute => 'restartable', value => TRUE);
     
 
    DBMS_SCHEDULER.SET_ATTRIBUTE(
             name => '"ZSNC57"."autoDeleteTemp"',
             attribute => 'logging_level', value => DBMS_SCHEDULER.LOGGING_FULL);
      
 
    
    DBMS_SCHEDULER.enable(
             name => '"ZSNC57"."autoDeleteTemp"');
END;

直接手动运行定时任务的方式(目前还没研究出来为啥一直报错):
begin
    dbms_scheduler.run_job('autoDeleteTemp',TRUE); -- true代表同步执行
end;

注:如果直接执行存储过程可以执行,但定时任务却始终执行不了,执行以下步骤:

select * from dba_sys_privs where grantee='oracle_user_name';
 查询一下当前用户被直接赋予的权限有哪些.如果没有的话执行下列赋权语句.
 grant create job to oracle_user_name;
 grant MANAGE SCHEDULER  to oracle_user_name;
 show parameter job;  --显示当前job参数,如果job_queue_processes = 0则执行下面语句修改.
 alter system set job_queue_processes = 1;

如果你的Job正常运行了,通过如下几张表可以查询到运行记录:

--Oracle定时任务
-- job信息
select * from user_scheduler_jobs;
--  job日志
select * from User_Scheduler_Job_Log;
-- job运行日志
select * from user_scheduler_job_run_details;
--正在运行的job
select * from user_scheduler_running_jobs;

在Oracle SQL developer中也有集成界面

Oracle定时任务Job笔记

Oracle定时任务Job笔记的更多相关文章

  1. EntityFramework CodeFirst SQLServer转Oracle踩坑笔记

    接着在Oracle中使用Entity Framework 6 CodeFirst这篇博文,正在将项目从SQLServer 2012转至Oracle 11g,目前为止遇到的问题在此记录下. SQL Se ...

  2. 最简单的一个Oracle定时任务

    最简单的一个Oracle定时任务一.在PLSQL中创建表:create table HWQY.TEST(CARNO     VARCHAR2(30),CARINFOID NUMBER) 二.在PLSQ ...

  3. oracle定时任务

    一.简介 当我们需要oracle数据库定时自动执行一些脚本,或进行数据库备份.数据库的性能优化,包括重建索引等工作是需要使用到定时任务. 定时任务可以使用以下两种完成. 1.操作系统级的定时任务,wi ...

  4. Oracle RAC学习笔记:基本概念及入门

    Oracle RAC学习笔记:基本概念及入门 2010年04月19日 10:39 来源:书童的博客 作者:书童 编辑:晓熊 [技术开发 技术文章]    oracle 10g real applica ...

  5. Oracle RAC学习笔记01-集群理论

    Oracle RAC学习笔记01-集群理论 1.集群相关理论概述 2.Oracle Clusterware 3.Oracle RAC 原理 写在前面: 最近一直在看张晓明的大话Oracle RAC,真 ...

  6. Oracle RAC学习笔记02-RAC维护工具集

    Oracle RAC学习笔记02-RAC维护工具集 RAC维护工具集 1.节点层 2.网络层 3.集群层 4.应用层 本文实验环境: 10.2.0.5 Clusterware + RAC 11.2.0 ...

  7. [Oracle]OWI学习笔记--001

    [Oracle]OWI学习笔记--001 在 OWI 的概念里面,最为重要的是 等待事件 和 等待时间. 等待事件发生时,需要通过 P1,P2,P3 查看具体的资源. 可以通过 v$session_w ...

  8. 【Oracle】使用dbms_job包创建Oracle定时任务

           在Oracle的包里面,有一个名字叫做DBMS_JOB的包,它的作用是安排和管理作业队列.通过作业队列,可以让Oracle数据库定期执行特定的任务.当使用DBMS_JOB管理作业的时候, ...

  9. oracle 定时任务例子【项目例子】

    说明:请在plsql工具的命令窗口中,依次按步骤执行如下脚本   (1)建立备份表 my_test_log2create table my_test_log2 as select * from my_ ...

随机推荐

  1. MongoDB 文档的删除操作

    在db中删除数据是十分危险的事,建议使用logic delete,即在doc中增加一个field:IsDeleted,将其设置为1,表示该doc在逻辑上被删除,这种workaround将delete操 ...

  2. 三台CentOS 5 Linux LVS 的DR 模式http负载均衡安装步骤

    Linux负载均衡软件LVS(概念篇) 一. LVS简介 LVS是Linux Virtual Server的简称,也就是Linux虚拟服务器, 是一个由章文嵩博士发起的*软件项目,它的官方站点是ww ...

  3. 博客标题栏增加一个"闪存“按钮

    最近来博客园喜欢去闪存上看看,也就是一个类似微博的东西,但是貌似没看到哪里有这个按钮. 所以只要自己动手搞一个. 暴力猴js: // ==UserScript== // @name fwindpeak ...

  4. Chromium网页Frame Tree创建过程分析

         Chromium在加载一个网页之前,需要在Browser进程创建一个Frame Tree.Browser进程为网页创建了Frame Tree之后,再请求Render进程加载其内容.Frame ...

  5. 1354 - IP Checking(水题)

    1354 - IP Checking   PDF (English) Statistics Forum Time Limit: 2 second(s) Memory Limit: 32 MB An I ...

  6. Mysql的执行计划各个参数详细说明

    执行计划各个参数的说明 1.id 主要是用来标识sql的执行顺序,如果没有子查询,一般来说id只有一个,执行顺序也是从上到下 2.select_type 每个select子句的类型 a:  simpl ...

  7. Windows中nvm使用

    介绍:在两个项目且使用的node版本不一样时,维护多个版本的node, 安装:下载安装目录:https://github.com/coreybutler/nvm-windows/releasesnvm ...

  8. 谁说java里面有返回值的方法必须要有返回值,不然会报错????

    慢慢的总是发现以前的学得时候有些老师讲的不对的地方! 所以还是尽量别把一些东西说的那么绝对,不然总是很容易误导别人,特别是一些你自己根本就没有试过的东西,然后又斩钉截铁的告诉别人,这样不行,肯定不行什 ...

  9. leetcode 280.Wiggle Sort 、324. Wiggle Sort II

    Wiggle Sort: 注意:解法一是每次i增加2,题目不是保证3个3个的情况,而是整个数组都要满足要求. 解法一错误版本: 如果nums的长度是4,这种情况下nums[i+1]会越界.但是如果你用 ...

  10. 004 Hadoop2.x基础知识

    一:大数据应用 1.Cloudera cloudera公司是Hadoop三大发行商之一,其版本为CDH版本,现在最新的版本是CDH5. 网站:http://archive.cloudera.com/c ...