在PL/SQL中如何让程序暂停几秒钟
在编写PL/SQL中,有时需要程序中暂停几秒钟再继续执行,查了一下,oracle内置有这个功能dbms_lock.sleep(10);不过dbms_lock包需要用户自己安装,演示如下:
- C:\Documents and Settings\andyleng>sqlplus /nolog
- SQL*Plus: Release 11.2.0.1.0 Production on Thu Nov 10 10:04:56 2011
- Copyright (c) 1982, 2010, Oracle. All rights reserved.
- SQL> conn /as sysdba --以SYSDBA身份登陆
- Connected.
- SQL> @?/rdbms/admin/dbmslock.sql --安装系统包
- Package created.
- Synonym created.
- Grant succeeded.
- SQL> grant execute on dbms_lock to public; --授权PUBLIC执行权限
- Grant succeeded.
- SQL> create table test1(id number,name varchar2(40),time date); --创建test1临时表
- Table created.
- SQL> select * from test1; --无数据
- no rows selected
- SQL> SET TIMING ON --打开时间显示
- SQL> begin --开始执行测试脚本
- 2 insert into test1(id,name,time) values(1,'Andy',sysdate);
- 3 DBMS_LOCK.SLEEP(10); --让程序暂时10秒钟
- 4 insert into test1(id,name,time) values(2,'Shirley',sysdate);
- 5 commit;
- 6 end;
- 7 /
- PL/SQL procedure successfully completed.
- Elapsed: 00:00:10.04 --程序执行时间为10.04秒
- SQL> SELECT ID,NAME,TO_CHAR(TIME,'YYYY/MM/DD HH24:MI:SS') AS TIME FROM TEST1; --查询执行结果
- ID NAME TIME
- ---------- ---------------------------------------- -------------------
- 1 Andy 2011/11/10 10:09:03 --第一条的插入时间是09:03
- 2 Shirley 2011/11/10 10:10:13 --第二条的插入时间是09:13,刚好比第一条晚了10秒钟
- Elapsed: 00:00:00.00
- SQL> drop table test1;
- Table dropped.
自定义EXCEPTION 和GOTO的用法:
- -- Create the procedure to loop del users.
- CREATE OR REPLACE PROCEDURE QA2_ATGCORE_MF.delBigTab
- AS
- PRAGMA AUTONOMOUS_TRANSACTION;
- p_Count NUMBER := 1000;
- n_delete number:=0;
- start_time date:=sysdate;
- end_time date;
- var_usergroup number;
- e_nowait EXCEPTION;--自定义exception
- PRAGMA EXCEPTION_INIT(e_nowait,-00054);--初使化该exception到“ORA-00054”的错误代码
- BEGIN
- <<restart>>--程序标签
- WHILE 1 = 1
- LOOP
- begin
- var_usergroup:=QA2_ATGCORE_MF.DEL_USERGROUP_SEQ.nextval;
- EXECUTE IMMEDIATE
- 'update QA2_ATGCORE_MF.DPS_USER_DEL_TEMP set usergroup_id=:usergroup,del_flag=''1'',del_time=sysdate where del_flag=''0'' and rownum <=:rn'
- USING var_usergroup,P_COUNT;
- IF (SQL%NOTFOUND)
- OR (TO_CHAR (SYSDATE, 'hh24mi') BETWEEN '0600' AND '1200')
- THEN
- EXIT;
- ELSE
- n_delete:=n_delete + SQL%ROWCOUNT;
- QA2_ATGCORE_MF.DEL_USERGROUP(var_usergroup);
- END IF;
- COMMIT;
- EXCEPTION
- WHEN e_nowait THEN
- DBMS_LOCK.SLEEP(2););--出现ORA-00054的错误时先等待2秒钟
- DBMS_OUTPUT.PUT_LINE(TO_CHAR(SYSDATE,'YYYY/MM/DD HH24:MI:SS')||SQLCODE||':'||SQLERRM||' I am go to restart' );
- GOTO restart;--出现ORA-00054的错误时跳转到restart处重新执行该程序
- WHEN OTHERS THEN
- ROLLBACK;
- RAISE;
- END;
- END LOOP;
- COMMIT;
- end_time:=sysdate;
- DBMS_OUTPUT.PUT_LINE('***************************************************************************');
- DBMS_OUTPUT.PUT_LINE('Totally delete '||to_char(n_delete)||' users! Used time:'||numtodsinterval (end_time-start_time,'DAY'));
- DBMS_OUTPUT.PUT_LINE('***************************************************************************');
- END;
- /
在PL/SQL中如何让程序暂停几秒钟的更多相关文章
- 在PL/SQL/sqlplus客户端 中如何让程序暂停几秒钟
1. how to check procedure exist: SQL> conn oper/oper123Connected.SQL> desc dbms_lock;PROCEDURE ...
- PL/SQL中SELECT总结
一.SELECT 语句的各个关键词的顺序及作用简解(这个我简略点写~) 1.SELECT 2.FROM 3.WHERE 4.GROUP BY ---对结果集进行分组,通常与聚合函数一起使用 5.H ...
- PL/SQL中批量执行SQL脚本(不可把所有的语句都复制到New SQL Windows)
PL/SQL中批量执行SQL脚本,不可把所有的语句都复制到New SQL Window,因为这样会导致缓冲区过大而进程卡死! 最好的办法是将要执行的SQL脚本存放到指定文件中,如C:\insert.s ...
- oracle PL/SQL(procedure language/SQL)程序设计(在PL/SQL中使用SQL)
在PL/SQL程序中,允许使用的SQL语句只有DML和事务控制语句,使用DDL语句是非法的.使用SELECT语句从数据库中选取数据时,只能返回一行数据.使用COMMIT, ROLLBACK, 和SA ...
- PL/SQL中LOOP循环控制语句
在PL/SQL中可以使用LOOP语句对数据进行循环处理,利用该语句可以循环执行指定的语句序列.常用的LOOP循环语句包含3种形式:基本的LOOP.WHILE...LOOP和FOR...LOOP. LO ...
- PL/Sql 中创建、调试、调用存储过程
存储过程的详细建立方法 1.先建存储过程 左边的浏览窗口选择 procedures ,会列出所有的存储过程,右击文件夹procedures单击菜单"new",弹出 template ...
- PL/SQL中如何执行DDL、SCL?
PL/SQL程序中不能直接执行DDL语句.为什么? 假设我们在pl/sql程序中有这样的一条DDL语句—— drop table emp:在第一次解析pl/sql中的“drop table emp;” ...
- pl/sql 中F8执行单行sql
pl/sql中设置: tools->preferences->sql window->AutoSelect statement
- 在PL/SQL中调用Oracle存储过程
存储过程 1 什么是存储过程? 用于在数据库中完成特定的操作或者任务.是一个PLSQL程序块,可以永久的保存在数据库中以供其他程序调用. 2 存储过程的参数模式 存储过程的参数特性: IN类型的参数 ...
随机推荐
- Linux 复制、移动覆盖文件不提示
# vi ~/.bashrc 如果你看到如下内容,以下命令都会用别名执行了,就是说自动加了 -i 参数 alias rm='rm -i'alias cp='cp -i'alias mv='mv - ...
- Servlet中Request的getAttribute getParameter 区别
1.从更深的层次考虑,request.getParameter()方法传递的数据,会从Web客户端传到Web服务器端,代表HTTP请求数据. request.getParameter()方法返回Str ...
- bootstrap基础学习八篇
bootstrap辅助类 a.对于文本颜色 以下不同的类展示了不同的文本颜色.如果文本是个链接鼠标移动到文本上会变暗: 类 描述 .text-muted "text-muted" ...
- python中paramiko的安装
windows下安装并使用Python的SSH模块(paramiko+pycrypto+ecdsa) 2014-01-20 14:59 2223人阅读 评论(0) 收藏 举报 python+opens ...
- boost实用工具:创建一个禁止复制的类 noncopyable
boost的noncopyable允许创建一个禁止复制的类,使用很简单,但很好用! C++ Code 12345678910111213141516171819202122232425262728 ...
- ETL概念,ETL流程
ETL是将业务系统的数据经过抽取.清洗转换之后加载到数据仓库的过程,目的是将企业中的分散.零乱.标准不统一的数据整合到一起,为企业的决策提供分析依据. ETL是BI项目重要的一个环节. 通常情况下,在 ...
- 编程之美 set 3 最大公约数问题
解法 1. f(x,y) = f(y, y%x) (y>0) 辗转相除法 2. 取模运算较为耗时, 将取模变成相减. 但对极端数据效果很差, 比如 gcd(1000,1) 3. 分析公约数的特点 ...
- Leetcode: Construct Binary Tree from Preorder and Inorder Traversal, Construct Binary Tree from Inorder and Postorder Traversal
总结: 1. 第 36 行代码, 最好是按照 len 来遍历, 而不是下标 代码: 前序中序 #include <iostream> #include <vector> usi ...
- solr初认识
Solr : Search On Lucene Replication Solr 基本概况 Apache Solr (读音: SOLer) 是一个开源的搜索服务器.Solr 使用 Java 语言开发, ...
- java基础---->hashSet的简单分析(一)
对于HashSet而言,它是基于HashMap实现的,底层采用HashMap来保存元素的.今天我们就简单的分析一下它的实现.人生,总会有不期而遇的温暖,和生生不息的希望. HashSet的简单分析 一 ...