Oracle创建存储过程,创建定时任务

在Oracle数据库中,创建存储过程和定时任务(也称为调度任务)是常见的数据库管理任务。以下是创建存储过程和定时任务的步骤和说明。

创建存储过程

创建存储过程的sql脚本

sql 复制代码
create or replace procedure 存储过程名称...
is
begin
  脚本逻辑...
COMMIT;
end;

脚本示例,将user表的数据插入到account表(注:这里我示例的两个表字段都是一样的,所以可以直接插,不一样的话需要调整一下insert语句)

sql 复制代码
create or replace procedure account_procedure
is
begin
  delete from account;
  insert into account
select * from user;
COMMIT;
end;

调用存储过程

sql 复制代码
--BEGIN
  --存储过程名称
--END
--示例
BEGIN
  ACCOUNT_PROCEDURE
END

删除存储过程

sql 复制代码
--DROP PROCEDURE 存储过程名称;
DROP PROCEDURE account_procedure;

创建定时任务

DBMS_JOB创建定时任务的脚本。

sql 复制代码
DECLARE
  job_id NUMBER;
BEGIN
  -- 创建定时任务
  SYS.DBMS_JOB.SUBMIT(
    job       => job_id,
    what      => 'ACCOUNT_PROCEDURE;', -- 要执行的PL/SQL代码或存储过程
    next_date => TRUNC(SYSDATE, 'DD') + 11/24, -- 下次执行时间为今天11点
    interval  => 'TRUNC(SYSDATE + 1, ''DD'') + 11/24', -- 每天11点执行
    no_parse  => TRUE
  );
  -- 输出确认信息
  DBMS_OUTPUT.PUT_LINE('Job Number is: ' || TO_CHAR(job_id));
  -- 提交事务
  COMMIT;
EXCEPTION
  WHEN OTHERS THEN
    -- 如果发生错误,输出错误信息
    DBMS_OUTPUT.PUT_LINE('创建定时任务时发生错误: ' || SQLERRM);
END;

删除定时任务的sql脚本

sql 复制代码
DECLARE
  job_id NUMBER;
BEGIN
  -- 查询 job_id
  SELECT job
  INTO job_id
  FROM user_jobs
  WHERE what = 'ACCOUNT_PROCEDURE;';
  -- 删除定时任务
  DBMS_JOB.REMOVE(job_id);
  -- 输出确认信息
  DBMS_OUTPUT.PUT_LINE('定时任务 ' || TO_CHAR(job_id) || ' 已成功删除。');
EXCEPTION
  WHEN NO_DATA_FOUND THEN
    -- 如果没有找到任务,输出错误信息
    DBMS_OUTPUT.PUT_LINE('没有找到匹配的定时任务。');
  WHEN OTHERS THEN
    -- 如果发生其他错误,输出错误信息
    DBMS_OUTPUT.PUT_LINE('删除定时任务时发生错误: ' || SQLERRM);
END;
相关推荐
极限实验室3 小时前
APM(一):Skywalking 与 Easyearch 集成
数据库·云原生
饕餮争锋3 小时前
SQL条件中WHERE 1=1 的功能
数据库·sql
玄斎4 小时前
MySQL 单表操作通关指南:建库 / 建表 / 插入 / 增删改查
运维·服务器·数据库·学习·程序人生·mysql·oracle
编织幻境的妖4 小时前
SQL查询连续登录用户方法详解
java·数据库·sql
编程小Y5 小时前
MySQL 与 MCP 集成全解析(核心原理 + 实战步骤 + 应用场景)
数据库·mysql·adb
零度@5 小时前
SQL 调优全解:从 20 秒到 200 ms 的 6 步实战笔记(附脚本)
数据库·笔记·sql
Miss_Chenzr5 小时前
Springboot优卖电商系统s7zmj(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·spring boot·后端
lvbinemail6 小时前
Grafana模板自动复制图表
数据库·mysql·zabbix·grafana·监控
Miss_Chenzr6 小时前
Springboot旅游景区管理系统9fu3n(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·spring boot·旅游
小虾米vivian6 小时前
dmetl5 运行失败,提示违反协议?
数据库·达梦数据库