- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
基于ORACLE实时C/S系统的实现
宁波港口EDI中心 贺伟国
摘 要 本文介绍了如何利用ORACLE调用外部过程的功能,开发基于ORACLE数据库的实时C/S系统。
关键词 ORACLE,VC,外部过程,实时系统。
1、引言
目前很多MIS系统是Client/Server架构,Client/Server应用系统基本运行关系体现为请求/响应的应答模式,每当用户需要访问服务器时就由客户机发出请求,服务器接受请求并响应,然后执行相应的服务,把执行结果送回给客户机,由它进一步处理后再提交给用户。
在实时性要求不高的系统中,客户机只要不定时的手工刷新数据就能当前后端数据库的最新内容,但是对于实时性要求比较高的系统,如果某一个客户机更新了数据,而其它客户机没有及时更新数据,继续对未更新的数据进行操作,就会引起数据库更新错误,严重点还会产生脏数据,导致系统出错;为了解决这一问题,可以有两个方法:一是客户端设置一个定时器,定时刷新数据;另外一个方法是当表的数据更新时,服务器端发送消息通知所有客户端更新数据,客户端收到消息后更新数据。本文就后一种方法进行介绍。
2、系统结构
系统的结构如下图:
每一个客户端连接数据库后,在数据库中登记客户端自身的IP地址和接收消息的udp端口,当其中的一个客户端对数据表进行操作后,数据库自动执行该表的触发器,该触发器调用系统的消息发送程序,将更新消息发送到每一个客户端,当客户端收到刷新消息后,刷新该表的数据,更新用户界面上的数据。本文用到的消息的传输协议是udp协议,因此在服务器上需要登记客户端接收udp消息的端口。当客户端退出后,需要注销登记的IP地址和端口。
3、Oracle调用外部过程介绍
由于oracle本身没有发送udp消息的API,因此需要利用操作系统的API进行这种操作。Oracle8i以上版本开始提供了直接调用用C语言写的动态连接库的功能,通过这一特性,可以用C写一个发送消息的动态连接库,然后在oracle的触发器中调用这个动态连接库,这样就能实现系统的要求。
为了让Oracle能够调用外部过程需要完成以下步骤:
用C语言对该过程编码并将它编译成一个动态连接库。
配置SQL*Net参数文件并启动监听器。
创建一个库数据字典对象以表示该操作系统库。
用PL/SQL创建一个wrapper过程以将PL/SQL参数映射为C参数。
3.1 配置SQL*Net监听器
监听器配置文件listener.ora文件格式:
listener=
(ADDERSS_LIST=
(ADDRESS=
(PROTOCOL=ipc)
(KEY=LISTENER_KEY)
)
)
sid_list_listener=
(SID_LIST=
(SID_DESC=
(SID_NAME=EXTPROC_SID)
(ORACLE_HOME=ORACLE_HOME)
(PROGRAM=extproc)
(ENVS=EXTPROC_DLLS=ANY)
)
)
这个文件的关键部分是SID列表的(PROGRAM=extproc)节,这一项指明这个链接将被用来分裂extproc,而不是连接到数据库上。
TNS文件tnsnames.ora格式:
Extproc_connection_data=
(DESCRIPTION=
(ADDRESS=
(PROTOCOL=ipc)
(key=LISTENER_KEY)
)
(CONNECT_DATA=
(SID=EXTPROC_SID)
)
)
需要注意的是listener.ora和tnsnames.ora中SID必须相同。
3.2 创建库
创建库的语法如下:
CREATE LIBRARY library_name {IS|AS}
‘operating_system_path’;
这里library_name是新库的名字,而operating_system_path是文件系统中共享库的完整路径(包括目录)。
例:
create library stringlib as
‘c:\test\stringlib.dll’;
此时数据库不会验证操作系统的动态连结库是否存在,只是在调用过程时才检测该库是否存在。
3.3 创建Wrapper过程(变换过程)
如果要调用一个外部过程,就必须创建一个Wrapper过程,该过程的作用是将PL/SQL参数映射为C参数,并且告诉PL/SQL外部库的名字。
创建Wrapper过程的语法如下:
CREATE PROCEDURE procedure_name [parameter_list]
AS EXTERNAL
LIBRARY librar
您可能关注的文档
最近下载
- 2024年城市管理网格员四级-中级理论知识试题及答案.docx VIP
- 2024年城市管理网格员三级(高级)理论知识考试试题及答案.docx VIP
- 2020-2021学年北京师大二附中实验学校九年级上学期期中数学试卷(含解析).pdf VIP
- 2025年城市管理网格员三级(高级)理论知识考试试题及答案.docx VIP
- 压力性尿失禁的护理查房PPT课件.pptx VIP
- 2024-2025学年辽宁铁道职业技术学院单招《英语》试卷及答案详解【典优】.docx VIP
- 辽宁铁道职业技术学院单招考试文化素质数学通关考试题库(完整版)附答案详解.docx VIP
- 学年西城区四中初三上学期期中数学试卷.pdf VIP
- 2019-2020学年北京四中九年级(上)期中数学试卷--含详细解析.docx VIP
- 中国餐饮企业发展报告.pptx VIP
文档评论(0)