Oracle的作业(用于数据库无法动态构建表名)

在日常学习中遇到了这样的一个问题,要创建一个视图,用于获取当前月和上月的数据,但是,数据表是每个月存一张表,那么想的就是写sql,然后动态构建表明,进行查询。但是很多办法都用了,没法支持动态构建表明,那么就写了一个作业,用于每个月重新更新一下视图。

要创建和调度一个作业,您可以使用 DBMS_SCHEDULER 包。下面是一个完整的代码示例,展示如何在Oracle数据库中创建一个作业,这个作业每月的第一天自动执行,用于更新视图以包含当前月和上个月的数据。

1. 创建动态SQL的PL/SQL块

首先,需要编写一个PL/SQL块,用于动态更新视图:

sql 复制代码
BEGIN
    -- 动态生成SQL以更新视图
    DECLARE
        current_month_table VARCHAR2(30);
        previous_month_table VARCHAR2(30);
        sql_query           VARCHAR2(1000);
    BEGIN
        -- 计算当前月和上个月的表名
        current_month_table := 'DATA_' || TO_CHAR(SYSDATE, 'YYYYMM');
        previous_month_table := 'DATA_' || TO_CHAR(ADD_MONTHS(SYSDATE, -1), 'YYYYMM');

        -- 生成SQL查询语句
        sql_query := 'CREATE OR REPLACE VIEW V_CURRENT_AND_PREV_MONTH_DATA AS ' ||
                     'SELECT * FROM ' || current_month_table ||
                     ' UNION ALL ' ||
                     'SELECT * FROM ' || previous_month_table;

        -- 执行动态SQL语句
        EXECUTE IMMEDIATE sql_query;
    END;
END;

2. 创建一个Scheduler作业

接下来,我们将这个PL/SQL块放入 DBMS_SCHEDULER.create_job 中,创建一个每月执行一次的作业。

sql 复制代码
BEGIN
    DBMS_SCHEDULER.create_job (
        job_name        => 'UPDATE_VIEW_JOB',
        job_type        => 'PLSQL_BLOCK',
        job_action      => '上边整个的动态SQL块',
        start_date      => SYSTIMESTAMP, -- 立即生效
        repeat_interval => 'FREQ=MONTHLY; BYMONTHDAY=1', -- 每月1日执行
        enabled         => TRUE -- 立即启用作业
    );
END;

3. 检查和管理作业

作业创建后,可以通过以下SQL语句查看已调度的作业:

sql 复制代码
SELECT job_name, enabled, repeat_interval, last_start_date, next_run_date
FROM dba_scheduler_jobs
WHERE job_name = 'UPDATE_VIEW_JOB';

4. 启停作业

如果需要暂停或启用作业,可以使用以下命令:

sql 复制代码
-- 暂停作业
BEGIN
    DBMS_SCHEDULER.disable('UPDATE_VIEW_JOB');
END;

-- 启用作业
BEGIN
    DBMS_SCHEDULER.enable('UPDATE_VIEW_JOB');
END;

5. 删除作业

如果不再需要这个作业,可以删除它:

sql 复制代码
BEGIN
    DBMS_SCHEDULER.drop_job('UPDATE_VIEW_JOB');
END;

这样,您就可以自动管理视图中的数据,并确保视图始终包含当前月和上个月的数据。视图在PL/SQL关闭也是可以存在的,没有任何问题。

相关推荐
切糕师学AI5 分钟前
HBase:一文搞懂分布式宽列数据库(原理 + 架构 + 实战)
数据库·分布式·nosql·hbase·分布式宽列数据库·wide column db
competes8 分钟前
慈善基金投资底层逻辑应用 顶层代码低代码配置平台开发结构方式数据存储模块
java·开发语言·数据库·windows·sql
qq_3729069339 分钟前
如何在 Vuetify 中可靠捕获 Chip 关闭事件(包括键盘触发)
jvm·数据库·python
lcj092466641 分钟前
磁控U位管理系统与DCIM对接实现:筑牢数据中心精细化运维底座
大数据·数据库·人工智能
独自归家的兔1 小时前
OCPP 1.6 协议详解:StatusNotification 状态通知指令
开发语言·数据库·spring boot·物联网
qq_372154232 小时前
SQL嵌套查询中常见报错排查_语法与权限处理
jvm·数据库·python
0xDevNull2 小时前
MySQL 别名(Alias)指南:从入门到避坑
java·数据库·sql
2401_887724503 小时前
CSS如何设置文字溢出显示省略号_利用text-overflowellipsis
jvm·数据库·python
m0_747854523 小时前
golang如何实现应用启动耗时分析_golang应用启动耗时分析实现思路
jvm·数据库·python
雪碧聊技术3 小时前
下午题_试题二
数据库