Oracle Scheduler学习

参考文档:
Primary Note: Overview of Oracle Scheduler (Doc ID 1485539.1)


Oracle® Database Administrator's Guide
12c Release 1 (12.1)
E17636-21
Chapter(30) Administering Oracle Scheduler
Examples of Using the Scheduler
http://docs.oracle.com/cd/E16655_01/server.121/e17636/schedadmin.htm#ADMIN12062

Oracle® Database Administrator's Guide
12c Release 1 (12.1)
E17636-21
Chapter(28) Oracle Scheduler Concepts
http://docs.oracle.com/cd/E16655_01/server.121/e17636/schedover.htm#ADMIN033

Oracle® Database PL/SQL Packages and Types Reference
12c Release 1 (12.1)
E17602-14
Chapter(138) DBMS_SCHEDULER
http://docs.oracle.com/cd/E16655_01/appdev.121/e17602/d_sched.htm#ARPLS72235

Oracle® Database 
Database Administrator’s Guide 19c 
E96348-16 September 2022
https://docs.oracle.com/en/database/oracle/oracle-database/19/admin/index.html

Creating a scheduler job that inserts the systimestamp into a table every second

SQL> create table messages (message varchar2(100) not null);Table created.SQL> select * from messages;no rows selectedSQL> Begin2    DBMS_SCHEDULER.CREATE_JOB (3             job_name             => 'job_runs_every_second',4             job_type             => 'PLSQL_BLOCK',5             job_action           => 'Begin insert into messages values (''Current Timestamp is: '' || SYSTIMESTAMP); commit; End;',6             start_date           => SYSTIMESTAMP,7             repeat_interval      => 'freq=secondly; interval=1',8             end_date             => null,9             enabled              => TRUE,10             comments             => 'A job scheduled to insert into messages table the current timestamp every second');11  End;12  /PL/SQL procedure successfully completed.SQL> Begin2    DBMS_SCHEDULER.RUN_JOB (job_name => 'job_runs_every_second');3  End;4  /PL/SQL procedure successfully completed.SQL> select * from messages;MESSAGE
----------------------------------------------------------------------------------------------------
Current Timestamp is: 24-AUG-12 04.57.00.647000 PM +02:00
Current Timestamp is: 24-AUG-12 04.57.01.624000 PM +02:00
Current Timestamp is: 24-AUG-12 04.57.02.757000 PM +02:00
Current Timestamp is: 24-AUG-12 04.57.03.807000 PM +02:00
Current Timestamp is: 24-AUG-12 04.57.04.816000 PM +02:00
Current Timestamp is: 24-AUG-12 04.57.05.814000 PM +02:00
Current Timestamp is: 24-AUG-12 04.57.06.813000 PM +02:00
Current Timestamp is: 24-AUG-12 04.57.07.812000 PM +02:00
Current Timestamp is: 24-AUG-12 04.57.08.813000 PM +02:00
Current Timestamp is: 24-AUG-12 04.57.09.810000 PM +02:0010 rows selected.SQL> Begin2    DBMS_SCHEDULER.DISABLE (name => 'job_runs_every_second', FORCE=>TRUE);3  End;4  /PL/SQL procedure successfully completed.SQL> Begin2    DBMS_SCHEDULER.DROP_JOB (job_name => 'job_runs_every_second');3  End;4  /PL/SQL procedure successfully completed.SQL> drop table messages;Table dropped.

Creating a scheduler job that gathers <USER> CBO stats every day at mid-night and every weekend day at 06:00 am

-- create weekdays schedule
SQL> Begin2    DBMS_SCHEDULER.CREATE_SCHEDULE (3        schedule_name => 'WEEKDAYS_MID_NIGHTS_SCHEDULE',4        start_date => NULL, -- If start_date is null, then the date that the job or window is enabled is used.5        repeat_interval => 'freq=daily;byhour=0;byminute=0;bysecond=0;byday=MON,TUE,WED,THU,FRI',6        end_date => NULL,7        comments => 'starts every day Mon-Fri at 12:00 am');8  End;9  /PL/SQL procedure successfully completed.-- create weekends schedule
SQL> Begin2    DBMS_SCHEDULER.CREATE_SCHEDULE (3        schedule_name => 'WEEKENDS_SCHEDULE',4        start_date => NULL, -- If start_date is null, then the date that the job or window is enabled is used.5        repeat_interval => 'freq=daily;byhour=6;byminute=0;bysecond=0;byday=SAT,SUN',6        end_date => NULL,7        comments => 'starts every weekend SAT-SUN at 06:00 am');8  End;9  /PL/SQL procedure successfully completed.-- create weekdays window
SQL> Begin2    DBMS_SCHEDULER.CREATE_WINDOW (3        window_name => 'WEEKDAYS_MID_NIGHTS_WINDOW',4        resource_plan => 'DEFAULT_MAINTENANCE_PLAN',5        schedule_name => 'WEEKDAYS_MID_NIGHTS_SCHEDULE',6        duration => '0 06:00:00',7        window_priority => 'HIGH',8        comments => 'window opens every day Mon-fri at 12:00 am and ends at 06:00 am');9  End;10  /PL/SQL procedure successfully completed.-- create weekends window
SQL> Begin2    DBMS_SCHEDULER.CREATE_WINDOW (3        window_name => 'WEEKENDS_WINDOW',4        resource_plan => 'DEFAULT_MAINTENANCE_PLAN',5        schedule_name => 'WEEKENDS_SCHEDULE',6        duration => '0 06:00:00',7        window_priority => 'HIGH',8        comments => 'window opens every Saturday & Sunday at 06:00 am');9  End;10  /PL/SQL procedure successfully completed.-- create a window group for both weekdays and weekends schedule
SQL> Begin2    DBMS_SCHEDULER.CREATE_GROUP (3     group_name => 'MAINTENANCE_GROUP',4     group_type => 'WINDOW',5     member => 'WEEKDAYS_MID_NIGHTS_WINDOW,WEEKENDS_WINDOW',6     comments => 'This group is designed for grouping weekdays and weekends maintenance windows');7  End;8  /PL/SQL procedure successfully completed.-- create stored procedure
SQL> CREATE OR REPLACE PROCEDURE "SYS"."GATHER_<USER>_STATISTICS_PROC" AS2  Begin3     DBMS_STATS.GATHER_SCHEMA_STATS(ownname => '<USER>', estimate_percent => 100);4  End;5  /Procedure created.-- create program that runs the stored procedure
SQL> Begin2    DBMS_SCHEDULER.CREATE_PROGRAM (3     program_name             => 'GATHER_<USER>_STATS_PROGRAM',4     program_type             => 'STORED_PROCEDURE',5     program_action           => '"SYS"."GATHER_<USER>_STATISTICS_PROC"',6     number_of_arguments      => 0,7     enabled                  => TRUE,8     comments                 => 'This is the program unit that calls the concerned stored procedure');9  End;10  /PL/SQL procedure successfully completed.-- create job
SQL> Begin2    DBMS_SCHEDULER.CREATE_JOB (3     job_name                => 'GATHER_<USER>_STATISTICS_JOB',4     program_name            => 'GATHER_<USER>_STATS_PROGRAM',5     schedule_name           => 'MAINTENANCE_GROUP',6     enabled                 => TRUE,7     auto_drop               => FALSE,8     comments                => 'Job that gathers CBO stats for <USER> schema everyday at 12:00 am and every weekend at 06:00 am',9     job_style               => 'REGULAR');10  End;11  /PL/SQL procedure successfully completed.

File Watcher Case Study

SQL*Plus: Release 12.1.0.1.0 Production on Thu Mar 6 13:31:09 2014Copyright (c) 1982, 2013, Oracle.  All rights reserved.Enter user-name: / as sysdbaConnected to:
Oracle Database 12c Enterprise Edition Release 12.1.0.1.0 - 64bit Production
With the Partitioning, OLAP, Advanced Analytics and Real Application Testing optionsSQL> --
SQL> -- Setting the monitoring repeat interval to 1 minute
SQL> --
SQL> begin2      dbms_scheduler.set_attribute ('FILE_WATCHER_SCHEDULE', 'REPEAT_INTERVAL', 'FREQ=MINUTELY;INTERVAL=1');3  end;4  /PL/SQL procedure successfully completed.SQL> grant dba to fw identified by fw;Grant succeeded.SQL> conn fw/fw
Connected.
SQL> --
SQL> -- creating necessary credential
SQL> --
SQL> begin2      dbms_scheduler.create_credential('FW_CREDENTIAL', 'Administrator', 'vcap4CEL');3  end;4  /PL/SQL procedure successfully completed.SQL> --
SQL> -- creating file watcher
SQL> --
SQL> begin2      dbms_scheduler.create_file_watcher (3          file_watcher_name => 'FW_FILE_WATCHER',4          directory_path => 'C:\xxx',5          file_name => '*.txt',6          credential_name => 'FW_CREDENTIAL',7          destination => null,8          enabled => false);9  end;10  /PL/SQL procedure successfully completed.SQL> --
SQL> -- creating monitoring table
SQL> --
SQL> create table fw_monitoring (2      file_timestamp timestamp with time zone,3      directory_path varchar2(4000),4      file_size number);Table created.SQL> --
SQL> -- creating procedure
SQL> --
SQL> create or replace procedure FW_PROC (fw_result in sys.scheduler_filewatcher_result) as2  begin3      insert into fw_monitoring values (4          fw_result.file_timestamp,5          fw_result.directory_path || '/' || fw_result.actual_file_name,6          fw_result.file_size);7  end;8  /Procedure created.SQL> --
SQL> -- creating program
SQL> --
SQL> begin2      dbms_scheduler.create_program (3          program_name => 'FW.FW_PROG',4          program_type => 'STORED_PROCEDURE',5          program_action => 'FW_PROC',6          number_of_arguments => 1,7          enabled => false);8  end;9  /PL/SQL procedure successfully completed.SQL> --
SQL> -- defining metadata argument
SQL> --
SQL> begin2      dbms_scheduler.define_metadata_argument (3          program_name => 'FW.FW_PROG',4          metadata_attribute => 'event_message',5          argument_position => 1);6  end;7  /PL/SQL procedure successfully completed.SQL> --
SQL> -- creating job
SQL> --
SQL> begin2      dbms_scheduler.create_job (3          job_name => 'FW.FW_JOB',4          program_name => 'FW.FW_PROG',5          event_condition => null,6          queue_spec => 'FW_FILE_WATCHER',7          auto_drop => false,8          enabled => false);9  end;10  /PL/SQL procedure successfully completed.SQL> --
SQL> -- setting parallel instances
SQL> --
SQL> begin2      dbms_scheduler.set_attribute ('FW.FW_JOB','PARALLEL_INSTANCES', true);3  end;4  /PL/SQL procedure successfully completed.SQL> --
SQL> -- enable program, job and file watcher
SQL> --
SQL> begin2      dbms_scheduler.enable ('FW.FW_PROG, FW.FW_JOB, FW_FILE_WATCHER');3  end;4  /PL/SQL procedure successfully completed.SQL> -- create <file.txt> in 'c:\xxx' folder
SQL> select to_char(sysdate, 'dd-mm-yyyy hh:mi:ss') as "current time" from dual;current time                                                                                                                                                                                                                                                                                         
-------------------                                                                                                                                                                                                                                                                                         
06-03-2014 01:27:54                                                                                                                                                                                                                                                                                         SQL> select * from fw_monitoring;no rows selectedSQL> -- wait for at least 1 minute
SQL> select to_char(sysdate, 'dd-mm-yyyy hh:mi:ss') as "current time" from dual;current time                                                                                                                                                                                                                                                                                                
-------------------                                                                                                                                                                                                                                                                                         
06-03-2014 01:29:00                                                                                                                                                                                                                                                                                         SQL> select * from fw_monitoring;FILE_TIMESTAMP                                               DIRECTORY_PATH                  FILE_SIZE                                                                                                  
------------------------------------------------------------ ------------------------------ ----------                                                                                                  
06-MAR-14 01.27.32.376000 PM +00:00                          C:\xxx/file.txt                      0                                                                                                  

END

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/62796.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

stable diffusion实践操作-提示词插件安装与使用

本文专门开一节写提示词相关的内容&#xff0c;在看之前&#xff0c;可以同步关注&#xff1a; stable diffusion实践操作 正文 1、提示词插件安装 1.1、 安装 1.2 加载【应用更改并重载前端】 1.3 界面展示 1.3.-4 使用 里面有个收藏列表&#xff0c;可以收藏以前的所有提示…

安全攻防基础以及各种漏洞库

安全攻防基础以及各种漏洞库 信息搜集企业信息搜集1. 企业架构2. ICP备案查询&#xff0c;确定目标子域名3. 员工信息&#xff08;搜集账号信息、钓鱼攻击&#xff09;4. 社交渠道 域名信息搜集IP搜集信息泄露移动端搜集打点进内网命令和控制&#xff08;持续控制&#xff09;穿…

CSC2121A

半桥架构的栅极驱动电路CSC2121A CSC2121系列是一款高性价比的半桥架构的栅极驱动专用电路&#xff0c;用于大功率MOS管、IGBT管栅极驱动。IC内部集成了逻辑信号处理电路、死区时间控制电路、欠压保护电路、电平位移电路、脉冲滤波电路及输出驱动电路&#xff0c;专用于无刷电…

10 行代码能做什么?

10 行代码能做什么&#xff1f; 写一串 SQL Join&#xff0c;统计全渠道市场营销的 ROI 用 JS 画个饼图&#xff0c;展示最有效的广告投放策略 用 Python 写段算法&#xff0c;分析销量骤降的原因是什么 …… 数据出错了&#xff0c;写个对数脚本 -_-|| AI 时代&#xff0c;…

SpringMVC之文件上传和下载

文章目录 前言一、文件下载二、文件上传总结 前言 实现下载文件和上传文件的功能。 一、文件下载 使用ResponseEntity实现下载文件的功能 RequestMapping("/testDown") public ResponseEntity<byte[]> testResponseEntity(HttpSession session) throws IOEx…

Zookeeper的使用

一、Zookeeper简介 分布式协调框架&#xff0c;小型的树形结构数据共享储存系统。 zookeeper的应用场景 集群管理 注册中心 配置中心 发布者将数据发布到ZooKeeper一系列节点上面&#xff0c;订阅者进行数据订阅&#xff0c;当数据有变化时&#xff0c;可及时得到数据的变…

Java基础二十三(枚举)

1> 枚举 在 Java 中&#xff0c;枚举&#xff08;Enum&#xff09;是一种特殊的数据类型&#xff0c;用于定义一组命名的常量。枚举常用于表示一组相关的常量&#xff0c;并且可以增加额外的属性和方法。 在 Java 中&#xff0c;枚举是一种类&#xff0c;可以定义成员变量和…

如何成为一个开发项目的负责人,需要哪些能力跟作为

目标&#xff1a;帮助项目解决一切障碍&#xff0c;让项目成员每天专心投入到工作中去&#xff0c;宁愿做错&#xff0c;也不能什么都不做。 最终目的&#xff1a;使项目在预期时间内完成&#xff0c;达到预期要求&#xff0c;甚至超出预期效果&#xff0c;同时形成公司自己的…

指针(个人学习笔记黑马学习)

1、指针的定义和使用 #include <iostream> using namespace std;int main() {int a 10;int* p;p &a;cout << "a的地址为&#xff1a;" << &a << endl;cout << "a的地址为&#xff1a;" << p << endl;…

Hive学习(12)Hive常用日期函数

1、hive返回当天三种方式 select current_date; --返回年月日 --2017-06-15 select current_timestamp; --返回年月日时分秒 --2017-06-15 19:54:44 SELECT from_unixtime(unix_timestamp()); --2017-06-15 19:55:042、from_unixtime&#xff1a;转化unix时间戳到当前时区的时…

如何自己实现一个丝滑的流程图绘制工具(八) 创建节点的文本标签

背景 节点的文本标签不希望是通过节点编辑实现&#xff0c;而是拿到节点名字渲染上去&#xff0c;包括连接线 createLabel(element, name, parent) {const modeling this.bpmnModeler.get(modeling)let labelCenter {}// 连接线上的标签if (element.type bpmn:SequenceFlo…

promethues监控postgres,emqx,redis

一、监控postgres 1、安装监控 docker pull wrouesnel/postgres_exporter2、执行 docker run -d -p 9187:9187 --name postgres_exporter --nethost -d -e DATA_SOURCE_NAME"postgresql://postgres:123456192.168.12.116:5432/rcc-manage?sslmodedisable" wroues…

centos 7的超详细安装教程

打开虚拟机&#xff0c;创建一个新电脑 我们选择经典&#xff0c;然后选择下一步 我们选择稍后安装&#xff0c;我们在后面进行改设备 因为centos系统是linux系统的一个版本&#xff0c;所有我们选择linux&#xff0c;版本选择centos 7 64位&#xff0c;然后就是点击下一步 这一…

Hive UDF自定义函数上线速记

0. 编写hive udf函数jar包 略 1. 永久函数上线 1.1 提交jar包至hdfs 使用命令or浏览器上传jar到hdfs,命令的话格式如下 hdfs dfs -put [Linux目录] [hdfs目录] 示例: hdfs dfs -put /home/mo/abc.jar /tmp1.2 将 JAR 文件添加到 Hive 中 注意hdfs路径前面要加上hdfs://na…

四、MySQL(表操作)如何添加字段?修改表?删除字段?修改表名?删除表?格式化某张表?

1、添加字段 &#xff08;1&#xff09;基础语法&#xff1a; alter table 表名 add 字段名 类型名(长度) [comment注释] [约束]; &#xff08;2&#xff09;示例&#xff1a;添加nickname这个字段 2、修改表 修改表中某个字段的【数据类型】/【数据类型&字段名】 &…

Microsoft Edge 主页启动diy以及常用的扩展、收藏夹的网站

一、Microsoft Edge 主页启动diy 二、常用的扩展 1、去广告&#xff1a;uBlock Origin 2、翻译&#xff1a; 页面翻译&#xff1a;右键就有了&#xff0c;已经内置了划词翻译 3、超级复制 三、收藏夹的网站

oracle中的(+)

一、()为何意&#xff1f; oracle中的&#xff08;&#xff09;是一种特殊的用法&#xff0c;&#xff08;&#xff09;表示外连接&#xff0c;并且总是放在非主表的一方。 二、举例 左外连接&#xff1a; select A.a,B.a from A LEFT JOIN B ON A.bB.b; 等价于 select A.a,B.…

Nacos 配置管理及相关使用

文章目录 Nacos 配置管理一、统一配置管理1、在Nacos 中添加配置文件2、从微服务拉取配置3、配置实现步骤&#xff08;1&#xff09;引入 nacos-config 依赖&#xff08;2&#xff09;添加 bootstrap.yml&#xff08;4&#xff09;在 nacos 中添加配置 二、配置热更新1、配置热…

嵌入式部署机器学习模型---TinyML

我们目前生活在一个被机器学习模型包围的世界。在一天中&#xff0c;您使用这些模型的次数比您意识到的要多。诸如浏览社交媒体、拍照、查看天气等日常任务都依赖于机器学习模型。您甚至可能会看到此博客&#xff0c;因为机器学习模型向您推荐了此博客。 我们都知道训练这些模型…

数据集汇总网站整理

1 综合数据集汇总网站 awesomedata/awesome-public-datasets: A topic-centric list of HQ open datasets. (github.com)各个领域的开源数据Find Open Datasets and Machine Learning Projects | KaggleKaggle竞赛的数据集天池大数据众智平台-阿里云天池 (aliyun.com)阿里云天…