动态网站制作指南



当前位置 > 网站建设学院 > 网络编程 > 数据库 > Oracle教程 Rss
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket

后台运行一个主存储过程,主存储过程通过管道同前端过程通信的例子


发表日期:2008-2-9



  beginmaXPRo为提交主存储过程起动的程序
  maxpro 为主存储过程
  readmaxpro 为主存佳话
  使用Oracle中的DBMS_PipE管道能力,注重要明文给于用户 EXECUTE ANY PROCEDURE 权力才可以
  在sqlpus用设定
  set serveroutput ON 进行测试
  通过 @testmaxpro.sql 创始程序包
  测试过程如下
  SQL> call beginmaxpro();
  JOB=62
  调用完成。
  SQL> call readmaxpro();
  maxpro 的当前进行状态为9
  调用完成。
  SQL>
  
  */
  --建立状态表
  create table mytest(mystatus integer);
  delete from mytest;
  INSERT INTO MYTEST(MYSTATUS) VALUES(0);
  commit;
  
  /
  --不可重用的存储过程,并且处理过程通过管道给ORACEL内的存储过程通信
  --使用ORACLE中的DBMS_PIPE管道能力,注重要明文给于用户 EXECUTE ANY PROCEDURE 权力才可以
  --首先 create table mytest(mystatus integer);
  -- INSERT INTO MYTEST(MYSTATUS) VALUES(0);
  --CREATE OR REPLACE PROCEDURE maxpro(P_NEXTDATE IN OUT DATE) AS
  CREATE OR REPLACE PROCEDURE maxpro AS
  
   n integer;
   status NUMBER;
  BEGIN
  --取当前状态
   SELECT mystatus INTO N FROM MYTEST;
  -- DBMS_OUTPUT.PUT_LINE('n=' n);
  
   IF N=1 THEN
   DBMS_OUTPUT.PUT_LINE('过程不可重入');
   RETURN;
   END IF;
  --过程调用lock
  UPDATE MYTEST SET MYSTATUS=1;
  COMMIT;
  --通过DBMS_LOCK.SLEEP(1); 模拟大的处理过程,过程处理一段时间后就将一些信息放入管道
  FOR N IN 1..30 LOOP
   DBMS_PIPE.PURGE('maxpro'); --清除原管道信息
   DBMS_PIPE.PACK_MESSAGE(N); --把信息放入缓冲区
   status:=DBMS_PIPE.SEND_MESSAGE('maxpro',1,100); --信息放入管道mypipe,系统等待时间为1秒,最大长度10000
   DBMS_LOCK.SLEEP(1);
  END LOOP;
  
  
  --过程调用unlock
   DBMS_PIPE.PURGE('maxpro'); --清除原管道信息
   DBMS_PIPE.PACK_MESSAGE(999999); --把信息放入缓冲区,999999 表示过程完成
  --信息放入管道mypipe,系统等待时间为1秒,最大长度110
  --原长度为100,现在设为110是担心长度不足出错
   status:=DBMS_PIPE.SEND_MESSAGE('maxpro',1,110);
  
  UPDATE MYTEST SET MYSTATUS=0;
  DBMS_OUTPUT.PUT_LINE('过程处理完成');
  COMMIT;
  --P_NEXTDATE:=NULL;
  END maxpro;
  /
  
  /*
  对于maxpro存储过程的状态进行读取的过程,主要使用读取管道的方法
  */
  CREATE OR REPLACE PROCEDURE readmaxpro AS
   n integer;
  status integer;
  begin
  
  --接受等待时间为1秒,可以为0,立即调用或DBMS_PIPE.RECEIVE_MESSAGE('mypipe') 等待100天
   status:= DBMS_PIPE.RECEIVE_MESSAGE('maxpro',0);
  --status为0为成功可以UNPACK_MESSAGE,1为超时没有数据,2为信息太大,3为内部错误
   IF status <> 0 THEN
   SELECT mystatus INTO N FROM MYTEST;
   IF N=0 THEN
   DBMS_OUTPUT.PUT_LINE('maxpro 过程没有起动');

   ELSE
   DBMS_OUTPUT.PUT_LINE('maxpro 过程起动,但管道中现在没有信息返回');
   END IF;
   return;
   END IF;
  
   DBMS_PIPE.UNPACK_MESSAGE(n);
   DBMS_OUTPUT.PUT_LINE('maxpro 的当前进行状态为' n);
  end;
  
  --起动maxpro为后台进程的存储过程
  /
  CREATE OR REPLACE PROCEDURE beginmaxpro AS
  JOB BINARY_INTEGER;
  BEGIN
  -- DBMS_JOB.SUBMIT(JOB,'maxpro;',sysdate,'sysdate+(5/(24*60*60))',TRUE);
  -- DBMS_JOB.SUBMIT(JOB,'maxpro;',sysdate,'sysdate+(60/(24*60*60))');
  --提交做业1秒后执行,注重设定实例ini文件中的job_queue_interval = 1
   DBMS_JOB.SUBMIT(JOB,'maxpro;',sysdate,NULL,FALSE);
  --DBMS_JOB.SUBMIT(JOB,'maxpro;',sysdate+(1/(24*60*60)),NULL,FALSE);
   DBMS_OUTPUT.PUT_LINE('JOB=' JOB);
   COMMIT;
  end;
  
  /
关注此文的读者还看过:
·2012-5-21 18:03:29 如何通过DB link进行远程过程或函数调用
·2012-5-21 18:03:22 SQL Server和Oracle的常用函数对比
·2012-5-21 18:02:47 [视频教程]玩转Oracle教程 第6讲(2)_plsql编程(2)
·2012-5-21 18:02:24 ORACLE入门之数据库安全策略
·2012-5-21 18:02:16 ResultSetsfromStoredProceduresInOracle
·2012-5-21 18:02:02 Oracle进程内存结构-如何察看Oracle进程消耗的内存
·2012-5-21 18:01:50 Oracle 10G的Data Pump (Part I)
·2012-5-21 18:01:18 如何解决二级联接打不开的问题
·2012-5-21 18:00:54 ORACLE回滚段的概念、用法和规划及问题解决
站长推荐 PS笔刷下载 在线翻译 系统进程 广告代码
  发表评论
姓 名: 验证码:
内 容:
教程搜索服务
项目外包信息
·汽车配件网站制作 50000元
·整站SEO优化
·课件门户网程序
·求长期合作网站设计制作高手
·公司网站重新改版 8000元
·asp企业网站小改动
·网站flash片头
·文化传播公司网站设计稿
·UI界面设计
·产品外观改版设计 15000元
·照明灯具网站设计 10000元
·求长期合作网站设计制作高手
·做B2C网站 20000元
·Android或QT软硬件平台设计(工
·网站首页FLASH
发布信息 浏览信息
邮件订阅服务
输入你的邮件地址,你将不会错过任何关于<Oracle教程>的内容


数据教程文章分类
SQL教程
SQL技巧
SQL安全
SQL文摘
Oracle教程
MySQL教程
Access教程
DB2教程
Sybase教程
站长工具:Google PR查询|Alexa排名查询|网站速度测试|CSS在线编辑器|OPEN参数生成器|弹出式窗口代码产生器|密码登录生成器|在线按钮生成器|Meta标签生成器|邮箱图标在线生成|多色彩特效字代码生成器|网页代码调试器|在线FTP登陆|Flash取色器|配色代码对照表|配色辞典|CSS生成器|CSS在线压缩|广告代码|框架网页代码生成器|js/vbs加密|md5加密|进制转换|UTF-8 转换工具|在线调色板|Html转换js|Html转换asp|Html转换php|Html转换perl
实用工具:汉字翻译拼音|拼音字典|在线翻译|天气预报|火星文|在线网速测试|符号对照表|个税计算|理财工具|黄金价格|购房银行按揭利率计算|汇率查询|经典小工具|汉字简繁转换|普通单位换算|公制单位换算|生辰老黄历|国内电话区号|国家代码与域名缩写|文字加密解密|元素周期表|健康查询|世界时间|全国各地车牌查询|全国车辆交通违章查询|万年历|二十四节气|汉字横竖排版|手机号码查询|计算器|ip搜索|酒店预订|机票预订
广告刊登 | 版权声明 | 联系我们 | 加入收藏 | RSS订阅
Copyright © 2000-2012 www.knowsky.com All rights reserved | 沪ICP备05001343号