掌握了 oracle中的 dbms_lock 函数,该函数 主要用于暂停执行的程序

1.用意

写job 以10分钟 为单元,前10分钟 从 1到10 插入测试表, 中间10分钟从 11到20插入测试表, 最后10分钟 从 21到30插入测试表.

2.处理方法

2.1 创建序列.  初始值 1  增量 1 最大值无限制

2.2 创建存储过程, 利用for循环顺序读取序列的nextval 插入 测试表.for循环中需要添加 sleep参数

2.3 创建job. 定期调用 存储过程, 参数repeat_interval    => 'FREQ=daily;INTERVAL=1',

/* every  day*/

2.4 创建测试表

3.创建测试表

SYS @ prod > CREATE TABLE TEST01(N1 DATE,N2 NUMBER);

Table created.

4.创建序列

--创建序列.  初始值 1  增量 1 最大值无限制

SYS @ prod >CREATE SEQUENCE MY_SEQ01 START WITH 1 INCREMENT BY 1 NOCACHE NOCYCLE;

Sequence created.

5.创建存储过程

--创建存储过程, 利用for循环顺序读取序列的nextval 插入 测试表.for循环中需要添加 sleep参数

SYS @ prod > CREATE OR REPLACE PROCEDURE BATCH_INSERT01

AS

BEGIN

FOR I IN 1..90 LOOP

INSERT INTO TEST01 VALUES(SYSDATE,MY_SEQ01.NEXTVAL);

COMMIT;

DBMS_LOCK.SLEEP(60);

END LOOP;

END;

/

Procedure created.

6.测试存储过程

SYS @ prod >exec BATCH_INSERT01;

PL/SQL procedure successfully completed.

7.创建 job

方法一:

SYS @ prod > DECLARE

BEGIN

DBMS_SCHEDULER.CREATE_JOB(

JOB_NAME =>'JOB_BATCH_INSERT01',

JOB_TYPE =>'STORED_PROCEDURE',

JOB_ACTION =>'BATCH_INSERT01',

START_DATE =>SYSDATE,

REPEAT_INTERVAL    => 'FREQ=MINUTELY;INTERVAL=1',        /* EVERY  MINUTE*/

ENABLED=> TRUE,

AUTO_DROP=> FALSE,

--  END_DATE           =>  ' 25-AUG-15 2.00.00 PM ',

COMMENTS           =>  'MY NEW JOB');

END;

/

PL/SQL procedure successfully completed.

8.强制命令程序暂停

--暂停10秒调用  DBMS_LOCK函数强制使程序暂停

BEGIN

DBMS_OUTPUT.PUT_LINE(TO_CHAR(SYSDATE,'YYYY-MM-DD HH24:MI:SS'));

DBMS_LOCK.sleep(10);

DBMS_OUTPUT.PUT_LINE(TO_CHAR(SYSDATE,'YYYY-MM-DD HH24:MI:SS'));

END;

2015-09-08 11:16:17

2015-09-08 11:16:27

9.运行job(不需要运行操作,因为job到指定时间会自动运行哦)

SYS @ prod >exec DBMS_SCHEDULER.RUN_JOB(JOB_NAME=>' job_batch_insert01');

PL/SQL procedure successfully completed.

10.查看对应包

包中分别包含了 运行job、删除job等存储过程

SYS @ prod >desc DBMS_SCHEDULER;

PROCEDURE RUN_JOB

Argument Name                  Type                    In/Out Default?

------------------------------ ----------------------- ------ --------

JOB_NAME                       VARCHAR2                IN

USE_CURRENT_SESSION            BOOLEAN                 IN     DEFAULT

PROCEDURE DROP_JOB

Argument Name                  Type                    In/Out Default?

------------------------------ ----------------------- ------ --------

JOB_NAME                       VARCHAR2                IN

FORCE                          BOOLEAN                 IN     DEFAULT

11.删除job

首先停止job

SQL> EXEC DBMS_SCHEDULER.STOP_JOB(JOB_NAME=>'JOB_BATCH_INSERT01');

PL/SQL procedure successfully completed.

再删除job

SYS @ prod > EXEC DBMS_SCHEDULER.DROP_JOB(job_name=>'job_batch_insert01');

PL/SQL procedure successfully completed.

12.检查结果

检查 测试表中的数据在增加

SQL> SELECT * FROM TEST01;

但是 查询 dba_jobs、user_jobs、all_jobs 没有任何信息

SQL> select * from dba_jobs;

SQL> select * from user_jobs;

no rows selected

SQL> select * from dba_jobs_running;

no rows selected

只在all_scheduler_job_log 中看到该job 运行的相关信息

SQL> set linesize 1000

SQL> set pagesize 1000

SQL> col log_date for a40

SQL> col job_name for a30

SQL> select log_date,job_name,status,destination  from all_scheduler_job_log order by log_date desc;

LOG_DATE                                 JOB_NAME                       STATUS               DESTINATION

--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

09-9月 -15 09.25.30.060000 上午 +08:00      JOB_BATCH_INSERT01                 SUCCEEDED

13.删除 序列、job、存储过程

SYS @ PROD >DROP PROCEDURE BATCH_INSERT01;

PROCEDURE DROPPED.

SYS @ PROD >DROP SEQUENCE MY_SEQ01;

SEQUENCE DROPPED.

SYS @ PROD >EXEC DBMS_SCHEDULER.DROP_JOB(JOB_NAME=>'JOB_BATCH_INSERT01');

PL/SQL PROCEDURE SUCCESSFULLY COMPLETED.

记录一下(以下为测试过程中用到的sql语句)

Plsql创建job

begin

sys.dbms_scheduler.create_job(job_name            => 'SJBDZFP.JOB_INSERT_TEST',

job_type            => 'STORED_PROCEDURE',

job_action          => 'sjbdzfp.insert_test',

start_date          => to_date('15-07-2015 10:00:00', 'dd-mm-yyyy hh24:mi:ss'),

repeat_interval     => 'Freq=Minutely;Interval=2',

end_date            => to_date('15-07-2015 12:00:00', 'dd-mm-yyyy hh24:mi:ss'),

job_class           => 'DBMS_JOB$',

enabled             => true,

auto_drop           => false,

comments            => 'My new job');

end;

/

副本1

create table test01 (n1 date,n2 number);

DROP TABLE TEST01 PURGE;

CREATE SEQUENCE MY_SEQ01 START WITH 1 INCREMENT BY 1 NOCACHE NOCYCLE;

SELECT * FROM MY_SEQ01.NEXTVAL FROM DUAL;

DROP SEQUENCE MY_SEQ01;

CREATE OR REPLACE PROCEDURE BATCH_INSERT01

AS

BEGIN

FOR I IN 1..90 LOOP

INSERT INTO TEST01 VALUES(SYSDATE,MY_SEQ01.NEXTVAL);

COMMIT;

DBMS_LOCK.SLEEP(60);

END LOOP;

END BATCH_INSERT01 ;

DECLARE

BEGIN

DBMS_SCHEDULER.CREATE_JOB(

JOB_NAME =>'JOB_BATCH_INSERT01',

JOB_TYPE =>'STORED_PROCEDURE',

JOB_ACTION =>'BATCH_INSERT01',

START_DATE =>SYSDATE,

REPEAT_INTERVAL    => 'FREQ=MINUTELY;INTERVAL=1',        /* EVERY DAY */

ENABLED=> TRUE,

AUTO_DROP=> FALSE,

--  END_DATE           =>  ' 25-AUG-15 2.00.00 PM ',

COMMENTS           =>  'MY NEW JOB');

END;

begin

DBMS_SCHEDULER.RUN_JOB(JOB_NAME=>'job_batch_insert01',USE_CURRENT_SESSION =>true);

end;

BEGIN

DBMS_SCHEDULER.job_stopped('job_batch_insert01');

END;

副本2

SELECT * FROM TEST01 ORDER BY N2 ASC;

DELETE FROM TEST01 ;

BEGIN

DBMS_SCHEDULER.stop_job('job_batch_insert01');

END;

BEGIN

DBMS_SCHEDULER.job_disabled('job_batch_insert01');

END;

BEGIN

DBMS_SCHEDULER.drop_job('job_batch_insert01');

END;

创建 序列 存储过程 job的更多相关文章

  1. 使用Navicat 创建mysql存储过程,实现日期加流水号序列

    目的:使用Navicat 创建mysql存储过程,实现格式为8位日期(年月日)+5位流水号序列. 步骤: 1.打开Navicat 登录数据库,点击导航栏上的函数,如下图: 2.点击新建函数,选择“过程 ...

  2. ORACLE通过JOB定时创建序列

    http://blog.csdn.net/cuihaiyang/article/details/7872982 因为业务需要每月需要增加一个序列,想到了使用job定时创建,每次创建一年的.写此job的 ...

  3. SQL Server 在多个数据库中创建同一个存储过程(Create Same Stored Procedure in All Databases)

    一.本文所涉及的内容(Contents) 本文所涉及的内容(Contents) 背景(Contexts) 遇到的问题(Problems) 实现代码(SQL Codes) 方法一:拼接SQL: 方法二: ...

  4. Oracle(创建序列)

    概念: 所谓序列,在oracle中就是一个对象,这个对象用来提供一个有序的数据列,这个有序的数据列的值都不重复. 1.序列可以自动生成唯一值 2.是一个可以被共享的对象 3.典型的用来生成主键值的一个 ...

  5. Oracle存储过程动态创建临时表/存储过程执行权限问题--AUTHID CURRENT_USER

    关于Oracle存储过程执行权限问题的解决 http://blog.sina.com.cn/s/blog_6ceed3280101hvlo.html (2014-04-02 04:06:28) 转载▼ ...

  6. 创建MySQL存储过程示例

    创建MySQL存储过程是学习MySQL数据库必须要掌握的知识,下文对创建MySQL存储过程作了详细的介绍,供您参考学习. AD:2013大数据全球技术峰会课程PPT下载 下文将教您如何创建MySQL存 ...

  7. DB2创建序列

    一.创建序列 序列是按照一定的规则生产的数值,序列的作用非常的大,比如银行交易中的流水号,就是记录每笔交易的关键字段. 通过create sequence语句创建序列,具体语法如下: >> ...

  8. MySql创建一个存储过程

    MySQL 存储过程是从 MySQL 5.0 新功能.存储过程的长处有一箩筐.只是最基本的还是运行效率和SQL 代码封装. 特别是 SQL 代码封装功能,假设没有存储过程,在外部程序訪问数据库时(比如 ...

  9. python推导式创建序列

    推导式创建序列 推导式是一个或多个迭代器快速创建序列的一种方式.可以将循环和条件判断结合,简化代码.几个推导式注意符号的使用,比如小括号,方括号,大括号等等. 列表推导式 列表推导式生成列表对象,语法 ...

随机推荐

  1. SCVMM更换数据库,如何搞?

    因为SCVMM和SQL不是集成在同一台机器上的. 所以,当SQL换机器或是换名字后,SCVMM就不能启动了. 并且MS没提供直观的更改数据库连接的工具,只是在安装的时候有选项. 网上找了方法,修改注册 ...

  2. QT中关闭应用程序和窗口的函数(quit(),exit()以及close()的区别)

    使用QT编辑界面,其中带来很大方便的一点就是Qt中自带丰富的.种类齐全的类及其功能函数,程序员可以在编辑程序的过程中简单地直接调用.关于窗口关闭的操作,在这里指出常用的三个槽,即quit(),exit ...

  3. CreateProcessWithLogonW(好像可以指定进程的上下文环境)

    Creates a new process and its primary thread. Then the new process runs the specified executable fil ...

  4. 模拟键盘发送文字(使用SendInput函数)

    嗯...老生常谈的话题, 不过系统的总结了一下, 找了个相对简单的实现方式, 可以方便的发送任何文字 参考另一片文章: http://www.cnblogs.com/-clq/archive/2011 ...

  5. C#验证码使用

    1.C#创建验证码 1.1 创建获取验证码页面(ValidateCode.aspx) <html xmlns="http://www.w3.org/1999/xhtml"&g ...

  6. COJ 0349 WZJ的旅行(五)

    WZJ的旅行(五) 难度级别:E: 运行时间限制:3000ms: 运行空间限制:262144KB: 代码长度限制:2000000B 试题描述 WZJ又要去旅行了T^T=0.幻想国由N个城市组成,由于道 ...

  7. Linux企业级开发技术(1)——epoll企业级开发之简介

    Epoll是当前在 Linux 下开发大规模并发网络程序的热门人选, Epoll 在 Linux2.6 内核中正式引入.和 select 相似,是高效 I/O 多路复用技术. 其实在 Linux 下设 ...

  8. super返回不过来

    class Fruit {     String color = "未确定颜色";     //定义一个方法,该方法返回调用该方法的实例     public Fruit getT ...

  9. 数据结构(线段树):HDU 5649 DZY Loves Sorting

    DZY Loves Sorting Time Limit: 12000/6000 MS (Java/Others)    Memory Limit: 262144/262144 K (Java/Oth ...

  10. 大小中型数据库和Oracle的常用命令

    一:大小中型数据库 二:基本命令 连接命令 1.conn[ect] 用法:conn 用户名/密码@网络服务器名[as sysdba/sysoper]当用特权用户身份连接时,必须带上as sysdba或 ...