动态网站制作指南 [  QQ表情  ]
[ 投票调查 ]
[ 企业邮箱 ]
[ 网站空间 ]
网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
ASP源码 | .Net源码 | PHP源码 | JSP源码 | JAVA源码 | CGI源码 | VB源码 | C++源码 | Delphi源码 | PB源码 | VF源码 | 汇编 | 服务器
电脑书籍下载:程序设计书籍 | 数据库教程书籍 | 平面与多媒体书籍 | 网络通讯书籍 | 系统管理书籍 | 网络安全书籍 | 认证考试书籍
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > 数据库 > Oracle教程
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
数据库:数据库教程,数据库技巧,Oracle教程,MySQL教程,Sybase教程,Access教程,DB2教程,数据库安全,数据库文摘
文章搜索服务
邮件订阅
输入你的邮件地址,
你将不会错过任何关于:
[ Oracle教程 ]的信息



本月文章推荐
.基础知识: HP-Unix下Oracle9i的.
.Oracle 恢复备份查询手册.
.如何恢复只有完好数据文件的Orac.
.oracle升级后exp出现oracle 942错.
.数据库恢复.
.Oracle数据操作和控制语言问题详.
.如何在sqlserver2000中实现oracl.
.ORACLE的分布式管理.
.Oracle学习应用之彻底地优化策略.
.MSSQL7.0SysbaseAccess向Oracle8.
.Qmail如何通过UUCP进行邮件外发.
.新手上路:Oracle基础工具简介.
.RedHat下Oracle启动脚本的建立.
.如何保持Oracle数据库优良性能.
.Oracle中的外连接简单介绍.
.oracle 学习笔记之一.
.AIX系统下的小型计算机系统接口性.
.Oracle安装(linux)总结一下.
.数据文件internal分析.
.如何给表、列加注释.

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

发表日期: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;
  
  /
上一篇:Oracle预定义角色有哪些? 人气:366
下一篇:ORACEL起动方法及一般问题 人气:345
浏览全部Oracle教程的内容 Dreamweaver插件下载 常用网页广告代码全集
  最新网站源码 最新软件下载
2008-7-23 Menalto Gallery v2.3 Rc1 多国语
2008-7-23 深度学习网址导航系统 v2.6.1
2008-7-23 因特达crm2008客户关系管理系统
2008-7-23 60度 CMS v1.0 Build 080723
2008-7-23 幻影动漫网视频系统(Ppdong) v1.
2008-7-23 好易祝福墙 2008
2008-7-23 APJE私服发布系统 v2.0 PHP版
2008-7-23 毕业论文在线指导系统源码
2008-7-23 Jacky法律在线网站源码
2008-7-19 UltraEdit 简体中文增强版 14.10
2008-7-19 CentOS 5.2 i386 LiveCD
2008-7-19 Snapture多功能相机 v1.4
2008-7-19 iAcces中文输入法 v1.0Build016
2008-7-19 Cookbook烹饪秘籍 v2.5
2008-7-19 苹果专用DVD转换工具 v1.1.59汉化
2008-7-19 Modem修复软件ZiPhone修改版04.0
2008-7-19 AgileMessenger即时通讯工具美化
2008-7-19 Sketches画图软件 v0.7b6破解版


  发表评论
姓 名: 验证码:
内 容:
[ 汉字翻译拼音 ] [ 广告代码 ] [ 符号对照表 ] [ 进制转换 ] [ 经典小工具 ] [ 个税计算 ] [ 汉字简繁转换 ] [ 普通单位换算 ] [ 公制单位换算 ]
[ 生辰老黄历 ] [ 国内电话区号 ] [ 国家代码与域名缩写 ] [ 文字加密解密 ] [ 健康查询 ] [ 万年历 ] [ 手机号码查询 ] [ ip搜索 ] [ Google PR查询 ]
业务联系 | 广告刊登 | 频道合作 | 投稿荐稿 | 联系方式 | 加入收藏 | RSS订阅
Copyright © 2000-2008 www.knowsky.com All rights reserved | 网络实名:动态网站制作指南 | 沪ICP备05001343号
ホームページ制作 不動産検索システム 求人情報
防水工事·改修工事 フットサル大会 探偵