• Crontab定时执行Oracle存储过程


    Crontab定时执行Oracle存储过程

    需求描述

    我们有一个Oracle的存储过程,里面是每个月需要执行一下,生成报表,然后发送给业务部门,这一个功能我们有实现在系统的前台界面(如图1-1),但是客户每次都不点重新生成,导致导出报表时报出异常(如图1-2)。

    图1-1

     

    图1-2

     

    问题分析

    既然它是一个存储过程,我们定位到了该请求相对应的存储过程,如下图所示

    图1-3

     

    我们看它的参数,只有两个,一个是开始时间,表示当月的开始时间,一个时结束时间,表示当月结束时间,我们只要在脚本执行它的时候传一个参数给它就可以。

    问题解决

    想要解决这个问题,我的想法是这样,把需要处理的所有逻辑写在脚本里,然后设定一个Crontab,通过定时任务去执行。

    一,首先看单纯在plsql是如何调用这个存储过程的,我通过定义一个startdate和enddate,然后通过Oracle的时间函数last_day计算出每月的最后一天,开始的第一天我是直接在月份拼接了'01',至于为什么add_months(sysdate,-1)要-1,是因为当月的一般执行上个月的。

    declare
    startdate varchar2(8);
    enddate varchar2(8);
    begin
    select to_char(add_months(sysdate,-1),'YYYYMM')||'01'
    into startdate from dual;
    select to_char(last_day(add_months(sysdate,-1)),'YYYYMMDD')
    into enddate from dual;
    proc_high_settle_rep_month(startdate,enddate);
    end;
    /

    二,把上述的逻辑写入到sh脚本中,我们在相关的路径新建一个文件call_proc_high_settle_rep_month.sh,通过执行sqlplus,然后去执行上述的内容

    脚本内容如下:

    其中sqlplus中的zh表示数据库账户名,*表示密码,zh10g表示数据库实例名,是你配置在tnsnames.ora的连接名。

    . /issdata/application/appiss/.profile
    echo "get begging"
    date
    sqlplus zh/*****@zh10g <<!
    declare
    startdate varchar2(20);
    enddate varchar2(20);
    begin
    select to_char(add_months(sysdate,-1),'YYYYMM')||'01'
    into startdate from dual;
    select to_char(last_day(add_months(sysdate,-1)),'YYYYMMDD')
    into enddate from dual;
    proc_high_settle_rep_month(startdate,enddate);
    end;
    /
    !
    echo "get Finished"

    三、手工执行了这个脚本,发现没错误,可以执行。

    sh call_proc_high_settle_rep_month.sh

    我们添加到crontab中,crontab -e进入crontab编辑,注意脚本要写绝对路径

    08 23 5 * * sh /tmp/call_proc_high_settle_rep_month.sh

    上述的crontab就代表每月的5号的23:08分就会执行这个命令。

    上面的08 23 5 * * 依次代表分、时、日、月、周。

    至此,整个程序已经实现好所有的逻辑,以后就算以后业务部分不点,也可以导出生成基础数据,报出报表了。

  • 相关阅读:
    如何很好的使用Linq的Distinct方法
    根据字符串获取对应类型(Type) 转
    .Net 读取xml
    认识ASP.NET MVC的5种AuthorizationFilter
    使用admin插入数据失败
    乱序批量精确修改文件名
    多进程+协程方案处理高IO密集,提升爬取效率
    Linux 安装 CMake
    Ubuntu 截图工具deepin-screenshot添加使用
    Linux virtualenv .bashrc配置文件
  • 原文地址:https://www.cnblogs.com/zhongfengshan/p/9356895.html
Copyright © 2020-2023  润新知