转至繁体中文版     | 网站首页 | 图文教程 | 资源下载 | 站长博客 | 图片素材 | 武汉seo | 武汉网站优化 | 
最新公告:     敏韬网|教学资源学习资料永久免费分享站!  [mintao  2008年9月2日]        
您现在的位置: 学习笔记 >> 图文教程 >> 数据库 >> ORACLE >> 正文
现用数据库         ★★★★

现用数据库

作者:闵涛 文章来源:闵涛的学习笔记 点击数:577 更新时间:2009/4/22 21:59:03


 
从数据库调用外部处理过程的方法

Oracle9i数据库的最大优点之一,从系统的观点来看它完全不只是一个被动的信息库。通过内建的PL/SQL和Java语言以及调用外部程序的功能,Oracle9i数据库能够启动并且完成各种处理任务。

然而,很多时候更需要完全在数据库之外运行一个处理过程。例如,若过程需要巨大的库来支持,那就要以多线程方式工作或访问由应用程序服务器提供的资源。或许你也想在另一台电脑上运行处理过程,那么你就不会占用全部数据库机器上的CPU的时间。

在本专栏中,我要讨论用于在数据库外面启动处理过程的两种流行的方法,并给出工作示例应用程序代码的概要来展示这些处理方法。

示例应用程序源于一个现实世界当中需要在数据库与应用程序服务器之间进行复杂交互的应用程序。下面是示例应用程序中描述的三种处理方案:

  1. 从PL/SQL调用一个HTTP来激活一个Java Servlet。

     

  2. 使用高级排队(AQ)功能来激活一个消息驱动的bean (MDB)。

     

  3. 使用AQ将数据库中的变化通知Java客户端应用程序。

 

图 1 即为该示例应用程序中的这些方案。

Architecture of the working sample 图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 中查找全部方案和工作代码示例以便了解更多的关于现用数据库的信息。



没有相关教程
教程录入:mintao    责任编辑:mintao 
  • 上一篇教程:

  • 下一篇教程:
  • 【字体: 】【发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口
      注:本站部分文章源于互联网,版权归原作者所有!如有侵权,请原作者与本站联系,本站将立即删除! 本站文章除特别注明外均可转载,但需注明出处! [MinTao学以致用网]
      网友评论:(只显示最新10条。评论内容只代表网友观点,与本站立场无关!)

    同类栏目
    · Sql Server  · MySql
    · Access  · ORACLE
    · SyBase  · 其他
    更多内容
    热门推荐 更多内容
  • 没有教程
  • 赞助链接
    更多内容
    闵涛博文 更多关于武汉SEO的内容
    500 - 内部服务器错误。

    500 - 内部服务器错误。

    您查找的资源存在问题,因而无法显示。

    | 设为首页 |加入收藏 | 联系站长 | 友情链接 | 版权申明 | 广告服务
    MinTao学以致用网

    Copyright @ 2007-2012 敏韬网(敏而好学,文韬武略--MinTao.Net)(学习笔记) Inc All Rights Reserved.
    闵涛 投放广告、内容合作请Q我! E_mail:admin@mintao.net(欢迎提供学习资源)

    站长:MinTao ICP备案号:鄂ICP备11006601号-18

    闵涛站盟:医药大全-武穴网A打造BCD……
    咸宁网络警察报警平台