图1: 工作示例应用程序的体系结构使用UTL_HTTPUTL_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 中查找全部方案和工作代码示例以便了解更多的关于现用数据库的信息。 新闻热点
疑难解答