网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
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认证人数最新统计.
.局域网的组建:用 Red Hat Linux.
.Oracle 10G 最佳20位新特性:等待.
.在oracle中限制返回结果集的大小.
.Oracle8 PL/SQL编程风格与系统性.
.解决Oracle下的undo空间过大的问.
.Oracle存储过程中任务和管道的应.
.甲骨文Sun联手 构建新10年战略伙.
.Oracle密码文件的使用和维护.
.关于Oracle 8.1.7安装时出现故障.
.关于惟一性、空间和数字等问题.
.实例讲解批处理程序突然变慢的解.
.系统对象IDL_UB1$表的含义及作用.
.数据库人员手册之ORACLE应用源码.
.oracle8i回滚段表空间出现坏块的.
.通过JDBC操纵Oracle数据库LOB字段.
.Oracle9i专题讲座精华.
.orale的tnsping与TCP/IP的ping命.
.杜绝安全隐患 容易忽视Oracle安全.
.Oracle回滚表空间数据文件误删除.

Oracle现用数据库

发表日期:2008-2-9


从数据库调用外部处理过程的方法 Oracle9i数据库的最大优点之一,从系统的观点来看它完全不只是一个被动的信息库。通过内建的PL/SQL和Java语言以及调用外部程序的功能,Oracle9i数据库能够启动并且完成各种处理任务。 然而,很多时候更需要完全在数据库之外运行一个处理过程。例如,若过程需要巨大的库来支持,那就要以多线程方式工作或访问由应用程序服务器提供的资源。或许你也想在另一台电脑上运行处理过程,那么你就不会占用全部数据库机器上的CPU的时间。 在本专栏中,我要讨论用于在数据库外面启动处理过程的两种流行的方法,并给出工作示例应用程序代码的概要来展示这些处理方法。 示例应用程序源于一个现实世界当中需要在数据库与应用程序服务器之间进行复杂交互的应用程序。下面是示例应用程序中描述的三种处理方案: 从PL/SQL调用一个HTTP来激活一个Java Servlet。
  使用高级排队(AQ)功能来激活一个消息驱动的bean (MDB)。
  使用AQ将数据库中的变化通知Java客户端应用程序。
  图 1 即为该示例应用程序中的这些方案。 Oracle现用数据库 图1: 工作示例应用程序的体系结构 使用UTL_HTTP UTL_HTTP提供的软件包使你能够从SQL和PL/SQL调出HTTP。在第一种方案中,当有新行插入到表格中时需要从远程网络服务器上提取一个文件,并将该文件保存在本地文件系统中。servlet将URL作为参数,来完成这项工作。A PL/SQL ON INSERT触发器使用UTL_HTTP来调用该servlet(它运行于Oracle9i应用程序服务器上)。UTL_HTTP的使用可能只是一个简单的单行调用,否则可以通过多个调用来处理诸如认证、代理以及cookies这一类的复杂过程。 我本可以使用UTL_HTTP来提取该文件和用UTL_FILE提供的软件包来保存该文件。然而,使用servlet都有助于保护数据库资源,并且使我有更多的调度选择。一个servlet能完成的各种任务的其它例子还包括调用Enterprise JavaBean(EJB)、给某人发送即时消息、操纵图像、进行CORBA调用。 使用高级排队功能 在数据库外面启动处理过程的另一个方法是将消息排入队列等候外部处理。AQ提供了基于Oracle9i Database而构建的消息传送功能。 在第二种方案中,需要调用一个Web服务来确认某些信息。PL/SQL程序将使用AQ将要发送到外部程序的消息进行排队。因为一条消息一经成功地排入队列,数据库的一个事务就能完成,所以在这种方法中,使用AQ能高效地将处理过程分解成前台处理和后台处理。 MDB是一种当新消息到达时便自动被调用的EJB。我用MDB将消息退出队列,并从Web服务检索某些相关的数据。MDB会向Web服务发送一个SOAP调用并用已更改的或已更新的信息对数据库进行更新。使用MDB是访问应用程序服务器提供的服务的一个非常棒的手段。 在第三种方案中,需要通知Java客户端应用程序数据库中的数据发生了变化,以便该应用程序对显示内容进行相应的更新。和前一种方案一样,当数据发生变化时PL/SQL触发器会将消息排入队列。 Java提供Java Message Service (JMS)应用编程接口(API)用于访问消息传送系统。我已经创建了一个Java应用程序来监控数据的变化。它用JMS将由PL/SQL触发器放入AQ的消息从队列中退出。 更多的活动 可在devtrends.oracle.com 中查找全部方案和工作代码示例以便了解更多的关于现用数据库的信息。

上一篇:配置UltraEdit为Oracle PL/SQL代码编辑器 人气:1233
下一篇:Oracle 数据对象分析 人气:534
浏览全部Oracle教程的内容 Dreamweaver插件下载 网页广告代码 祝你圣诞节快乐 2009年新年快乐