网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
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!
当前位置 > 网站建设学院 > 网络编程 > 数据库 > SQL技巧
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
网络编程:ASP教程,ASP.NET教程,PHP教程,JSP教程,C#教程,数据库,XML教程,Ajax,Java,Perl,Shell,VB教程,Delphi,C/C++教程,软件工程,J2EE/J2ME,移动开发
数据库:数据库教程,数据库技巧,Oracle教程,MySQL教程,Sybase教程,Access教程,DB2教程,数据库安全,数据库文摘
本月文章推荐
.深入讲解有关数据挖掘的10个常见.
.教你轻松解决数据库非事务表回滚.
.怎么样把sql server 2000的用户表.
.SQL Server 数据库管理常用的SQL.
.讲解触发器中的inserted表和dele.
.从旧版本SQL Server中重新存储数.
.列出SQL SERVER 所有表,字段名,.
.微软SQL Server 2008 CTP版的特性.
.50种方法巧妙优化你的SQL Server.
.SQL Server编写存储过程小工具(一.
.快速清除SQLServer日志的两种方法.
.Mssql批量修改权限.
.SQL Server 2005数据库备份和恢复.
.SQL Server 2000和 SQL Server 2.
.实例讲解两台SQL Server数据同步.
.经常用到的交叉表问题,一般用动态.
.轻松掌握SQL Server中各个系统表.
.SQL Server全文检索简介.
.SQL 2000中非域环境下数据库的异.
.讲解SQL Server海量数据导入的最.

借助两个开发包在PL/SQL中实现多进程通信

发表日期:2008-6-20


PL/SQL是基于Oracle的一个主流应用程序编程语言,它的主要特点是将SQL语句与过程化程序开发语言相结合,以实现更为复杂的商业逻辑。本文主要就其中多进程通信进行讨论。

显然,多进程技术是用来提高应用的并发性,进而提高整个系统的执行效率,那么如何在PL/SQL中实现多进程的通信呢?其实,PL/SQL其设计的初衷主要是增强SQL语句的功能,而没有考虑到其他编程语言的高级功能,所以在PL/SQL中实现多进程通信只能借助于Oracle提供的两个开发包:DBMS_PIPE和DBMS_ALERT。

1.DBMS_PIPE

该包提供多进程之间管道通信的方法,比如连接到同一个数据库的两个独立会话之间可以通过管道进行通信,另外也可以在存储过程和Pro*C之间进行通信,这样就大大地增强了PL/SQL的处理能力。该包主要提供两对函数:

pack_message(v_msg varchar2)-----将v_msg信息打包放入到缓冲器中,准备发送;

send_message(v_pipename varchar2)-----发送名为v_pipename的管道的缓冲器;

unpack_message(v_msg varchar2)-----将信息解析到v_msg中;

receive_message(v_pipename varchar2)----接受名为v_pipename的管道的缓冲器;

其执行的原理是:首先建立有名管道(这点熟悉unix很清楚),管道的发送端和接受端都有相应的缓冲器进行接受和发送处理,要注意的是,文本信息必须打包来发送,通过解析来读取信息。

为了理解前面的描述,下面列举一个两个会话之间通信的实例。

发送进程:

declare

v_pipename varchar2(30):='pipe1';

v_status integer;

begin

dbms_pipe.pack_message(' hello,this is sending process!');

v_status:=dbms_pipe.send_message(v_pipename);

if v_status !=0 then

dbms_output.put_line('error!');

end if;

end;

/

接受进程:

declare

v_pipename varchar2(30):='pipe1';

v_status integer;

v_msg varchar2(20);

begin

v_status:=dbms_pipe.receive_message(v_pipename);

if v_status !=0 then

dbms_output.put_line('error');

end if;

dbms_pipe.unpack_message(v_msg);

dbms_output.put_line(v_msg);

end;

/

2.DBMS_ALERT

与DBMS_PIPE类似,DBMS_ALERT可以实现多个进程(会话)之间的通信。其基本的执行过程为:首先建立一个报警通道,然后通过报警通道来发送报警信号;在接收端需要先注册该报警通道,对该通道进行监听,然后等待报警信号的到来。下面是该包中的主要函数说明:

dbms_alert.signal(报警管道名,待发送消息)---发送报警信息;

dbms_alert.reGISter(报警管道名)------注册报警管道;

dbms_alert.waitone(报警管道名,接受消息值,返回状态值)-------对报警管道进行监听,等待消息的到来;

同样,这里也给出使用DBMS_ALERT的一个实例。

发送进程:

declare

v_alertName varchar2(30):='alert1';

begin

dbms_alert.signal(v_alertName,' hello,this is sending process!');

commit;

end;

/

接受进程:

declare

v_alertName varchar2(30):='alert1';

v_status integer;

v_msg varchar2(20);

begin

dbms_alert.register(v_alertName);

dbms_alert.waitone(v_alertName,v_msg,v_status);

if v_status !=0 then

dbms_output.put_line('error');

end if;

dbms_output.put_line(v_msg);

end;

/

3.说明

DBMS_PIPE和DBMS_ALERT这两个包都可以进行多进程间的通信,但两者任然是有一些区别:

(1) 报警信号是同步的。报警信号直到会话发出Commit时才被发出;如果它所处的事务回滚,则该信号就不发送了。但是管道信号是异步的,而且其通信过程不受事务提交和回滚的影响。

(2) 沿着管道进行传递的消息只能被一个进程进行处理,其消息的接收方式是拷贝后删除,但是报警信号可以被多个进程所获得,即消息的接收方式仅仅是拷贝。

(3) 管道消息不仅可以传递文本信息,还可以传递其他信息,比如对象等,这一好处得益于其对消息的打包预处理;而报警消息只能是文本,不能是其他类型。

4.总结

近年来,虽然多进程应用有逐渐被多线程应用取代的趋势,但是多进程仍然有其适用的空间,希望读者通过本文初浅的介绍,对基于PL/SQL的多进程通信这一技术有一个初步的认识,这样为以后深入的开发打下一定的基础。

上一篇:SQLite数据库用来处理锁定情况的两个函数 人气:1046
下一篇:触发器中的inserted表和deleted表介绍 人气:1247
浏览全部PL/SQL的内容 Dreamweaver插件下载 网页广告代码 祝你圣诞节快乐 2009年新年快乐