PLSQL是基于Oracle一个主流应用程序编程语言.docVIP

PLSQL是基于Oracle一个主流应用程序编程语言.doc

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
PLSQL是基于Oracle一个主流应用程序编程语言

 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;

文档评论(0)

xcs88858 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

版权声明书
用户编号:8130065136000003

1亿VIP精品文档

相关文档