在编写PL/SQL中,有时需要程序中暂停几秒钟再继续执行,查了一下,oracle内置有这个功能dbms_lock.sleep(10);不过dbms_lock包需要用户自己安装,演示如下:

  1. C:\Documents and Settings\andyleng>sqlplus /nolog
  2. SQL*Plus: Release 11.2.0.1.0 Production on Thu Nov 10 10:04:56 2011
  3. Copyright (c) 1982, 2010, Oracle.  All rights reserved.
  4. SQL> conn /as sysdba  --以SYSDBA身份登陆
  5. Connected.
  6. SQL> @?/rdbms/admin/dbmslock.sql --安装系统包
  7. Package created.
  8. Synonym created.
  9. Grant succeeded.
  10. SQL> grant execute on dbms_lock to public; --授权PUBLIC执行权限
  11. Grant succeeded.
  12. SQL> create table test1(id number,name varchar2(40),time date);   --创建test1临时表
  13. Table created.
  14. SQL> select * from test1;  --无数据
  15. no rows selected
  16. SQL> SET TIMING ON  --打开时间显示
  17. SQL> begin  --开始执行测试脚本
  18. 2    insert into test1(id,name,time) values(1,'Andy',sysdate);
  19. 3    DBMS_LOCK.SLEEP(10);  --让程序暂时10秒钟
  20. 4    insert into test1(id,name,time) values(2,'Shirley',sysdate);
  21. 5    commit;
  22. 6  end;
  23. 7  /
  24. PL/SQL procedure successfully completed.
  25. Elapsed: 00:00:10.04  --程序执行时间为10.04秒
  26. SQL> SELECT ID,NAME,TO_CHAR(TIME,'YYYY/MM/DD HH24:MI:SS') AS TIME FROM TEST1; --查询执行结果
  27. ID NAME                                     TIME
  28. ---------- ---------------------------------------- -------------------
  29. 1 Andy                                     2011/11/10 10:09:03   --第一条的插入时间是09:03
  30. 2 Shirley                                  2011/11/10 10:10:13   --第二条的插入时间是09:13,刚好比第一条晚了10秒钟
  31. Elapsed: 00:00:00.00
  32. SQL> drop table test1;
  33. Table dropped.

自定义EXCEPTION 和GOTO的用法:

    1. -- Create the procedure to loop del users.
    2. CREATE OR REPLACE PROCEDURE QA2_ATGCORE_MF.delBigTab
    3. AS
    4. PRAGMA AUTONOMOUS_TRANSACTION;
    5. p_Count   NUMBER := 1000;
    6. n_delete number:=0;
    7. start_time date:=sysdate;
    8. end_time date;
    9. var_usergroup number;
    10. e_nowait EXCEPTION;--自定义exception
    11. PRAGMA EXCEPTION_INIT(e_nowait,-00054);--初使化该exception到“ORA-00054”的错误代码
    12. BEGIN
    13. <<restart>>--程序标签
    14. WHILE 1 = 1
    15. LOOP
    16. begin
    17. var_usergroup:=QA2_ATGCORE_MF.DEL_USERGROUP_SEQ.nextval;
    18. EXECUTE IMMEDIATE
    19. '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'
    20. USING var_usergroup,P_COUNT;
    21. IF (SQL%NOTFOUND)
    22. OR (TO_CHAR (SYSDATE, 'hh24mi') BETWEEN '0600' AND '1200')
    23. THEN
    24. EXIT;
    25. ELSE
    26. n_delete:=n_delete + SQL%ROWCOUNT;
    27. QA2_ATGCORE_MF.DEL_USERGROUP(var_usergroup);
    28. END IF;
    29. COMMIT;
    30. EXCEPTION
    31. WHEN e_nowait THEN
    32. DBMS_LOCK.SLEEP(2););--出现ORA-00054的错误时先等待2秒钟
    33. DBMS_OUTPUT.PUT_LINE(TO_CHAR(SYSDATE,'YYYY/MM/DD HH24:MI:SS')||SQLCODE||':'||SQLERRM||' I am go to restart' );
    34. GOTO restart;--出现ORA-00054的错误时跳转到restart处重新执行该程序
    35. WHEN OTHERS THEN
    36. ROLLBACK;
    37. RAISE;
    38. END;
    39. END LOOP;
    40. COMMIT;
    41. end_time:=sysdate;
    42. DBMS_OUTPUT.PUT_LINE('***************************************************************************');
    43. DBMS_OUTPUT.PUT_LINE('Totally delete '||to_char(n_delete)||' users! Used time:'||numtodsinterval (end_time-start_time,'DAY'));
    44. DBMS_OUTPUT.PUT_LINE('***************************************************************************');
    45. END;
    46. /

在PL/SQL中如何让程序暂停几秒钟的更多相关文章

  1. 在PL/SQL/sqlplus客户端 中如何让程序暂停几秒钟

    1. how to check procedure exist: SQL> conn oper/oper123Connected.SQL> desc dbms_lock;PROCEDURE ...

  2. PL/SQL中SELECT总结

      一.SELECT 语句的各个关键词的顺序及作用简解(这个我简略点写~) 1.SELECT 2.FROM 3.WHERE 4.GROUP BY ---对结果集进行分组,通常与聚合函数一起使用 5.H ...

  3. PL/SQL中批量执行SQL脚本(不可把所有的语句都复制到New SQL Windows)

    PL/SQL中批量执行SQL脚本,不可把所有的语句都复制到New SQL Window,因为这样会导致缓冲区过大而进程卡死! 最好的办法是将要执行的SQL脚本存放到指定文件中,如C:\insert.s ...

  4. oracle PL/SQL(procedure language/SQL)程序设计(在PL/SQL中使用SQL)

    在PL/SQL程序中,允许使用的SQL语句只有DML和事务控制语句,使用DDL语句是非法的.使用SELECT语句从数据库中选取数据时,只能返回一行数据.使用COMMIT,  ROLLBACK, 和SA ...

  5. PL/SQL中LOOP循环控制语句

    在PL/SQL中可以使用LOOP语句对数据进行循环处理,利用该语句可以循环执行指定的语句序列.常用的LOOP循环语句包含3种形式:基本的LOOP.WHILE...LOOP和FOR...LOOP. LO ...

  6. PL/Sql 中创建、调试、调用存储过程

    存储过程的详细建立方法 1.先建存储过程 左边的浏览窗口选择 procedures ,会列出所有的存储过程,右击文件夹procedures单击菜单"new",弹出 template ...

  7. PL/SQL中如何执行DDL、SCL?

    PL/SQL程序中不能直接执行DDL语句.为什么? 假设我们在pl/sql程序中有这样的一条DDL语句—— drop table emp:在第一次解析pl/sql中的“drop table emp;” ...

  8. pl/sql 中F8执行单行sql

    pl/sql中设置: tools->preferences->sql window->AutoSelect statement

  9. 在PL/SQL中调用Oracle存储过程

    存储过程 1 什么是存储过程? 用于在数据库中完成特定的操作或者任务.是一个PLSQL程序块,可以永久的保存在数据库中以供其他程序调用. 2 存储过程的参数模式 存储过程的参数特性: IN类型的参数 ...

随机推荐

  1. 关于跨平台的理解以及Unity的由来--Unity学习

    1.在2000到2003年的时候,掀起了一阵Java跨平台的浪潮,Java本来是在自己的Java机器上运行的,这时候出现了一个叫Java虚拟机的东西,Java虚拟机可以在Windows系统中运行,这样 ...

  2. javascript实现URL编码与解码

    一.预备知识 URI是统一资源标识的意思,通常我们所说的URL只是URI的一种.典型URL的格式如下所示.下面提到的URL编码,实际上应该指的是URI编码. foo://example.com:804 ...

  3. CefGlue 学习杂记

    1. hg clone代码回来后,还要下载对应的cef dll .  从http://xilium.bitbucket.org/cefglue/ 选择对应的. 然后把dll和resource目录里的内 ...

  4. 利用新浪云平台(SAE) 搭建 HUSTOJ 简易教程

    前言: OnlineJudge(OJ)是一种代码在线判定平台,这里有许多的编程题目供你选择,你可以选择题目提交代码,OJ会自动返回你的代码的判定结果.是一种很方便的编程.算法练习平台.详情可见:百度百 ...

  5. v8随心记

    因为node原因,研究v8已经有段时间了,但是一直也没有抽空写点什么,现在想想有好多当时清晰的东西又模糊了.哎,伤心的很啊.但是一时又想不起什么章法,所以只能随手胡乱写了. 下载.编译: https: ...

  6. 剑指 offer set 13 把数组排成最小的数

    总结 1. 给定 3, 32, 321 将他们组合成最小的数, 比如 321323 2. 3    ->   333 32   ->   322 321 ->   321 然后再排序

  7. 第二篇:CUDA 并行编程简介

    前言 并行就是让计算中相同或不同阶段的各个处理同时进行. 目前有很多种实现并行的手段,如多核处理器,分布式系统等,而本专题的文章将主要介绍使用 GPU 实现并行的方法. 参考本专题文章前请务必搭建好 ...

  8. std__vector介绍

    vector是C++标准模板库中的部分内容,它是一个多功能的,能够操作多种数据结构和算法的模板类和函数库.vector之所以被认为是一个容器,是因为它能够像容器一样存放各种类型的对象,简单地说,vec ...

  9. github 's usage

    author:headsen  chen date: 2018-05-30   10:50:56 notice:This  article is created by headsen chen him ...

  10. js对用户信息加密传输 java后端解密

    1.加密采用服务端随机生成加密因子放入session中,传入登录或注册界面(每次进入都刷新) 2.页面中引入jquery.aes.js(这个js从网上下的坑比较多,引入先后顺序不一致都会报错,所以最后 ...