[go: up one dir, main page]
More Web Proxy on the site http://driver.im/

JP4403065B2 - Information processing method and apparatus - Google Patents

Information processing method and apparatus Download PDF

Info

Publication number
JP4403065B2
JP4403065B2 JP2004377409A JP2004377409A JP4403065B2 JP 4403065 B2 JP4403065 B2 JP 4403065B2 JP 2004377409 A JP2004377409 A JP 2004377409A JP 2004377409 A JP2004377409 A JP 2004377409A JP 4403065 B2 JP4403065 B2 JP 4403065B2
Authority
JP
Japan
Prior art keywords
sql
xml web
statement
return
web service
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Expired - Fee Related
Application number
JP2004377409A
Other languages
Japanese (ja)
Other versions
JP2006185125A (en
Inventor
秀己 黒口
守康 不破
功一 古倉
Original Assignee
株式会社C−Grip
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by 株式会社C−Grip filed Critical 株式会社C−Grip
Priority to JP2004377409A priority Critical patent/JP4403065B2/en
Publication of JP2006185125A publication Critical patent/JP2006185125A/en
Application granted granted Critical
Publication of JP4403065B2 publication Critical patent/JP4403065B2/en
Anticipated expiration legal-status Critical
Expired - Fee Related legal-status Critical Current

Links

Images

Landscapes

  • Management, Administration, Business Operations System, And Electronic Commerce (AREA)
  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)

Description

本発明は、複数XML Webサービスの処理全体に対して、1トランザクションとして管理し、完全性を保証するXML Webサービスを実現するための情報処理方法及び装置に関する。   The present invention relates to an information processing method and apparatus for realizing an XML Web service that manages the entire processing of a plurality of XML Web services as one transaction and guarantees integrity.

企業等での業務用コンピュータシステムを構築するための手段として、嘗ては大型汎用機で全処理を行うホスト集中型システムが主流であったが、近年のパーソナルコンピュータ(PC)及びワークステーションの高性能・低価格化により、機能の一部をクライアントPCに持たせ、サーバと協調して稼働するクライアント・サーバ型システム(以下「C/Sシステム」という)が主流となってきた。   As a means for constructing a computer system for business use in a company or the like, a host-centralized system that performs all processing with a large general-purpose machine has been the mainstream, but recent high performance of personal computers (PCs) and workstations.・ Due to lower prices, client / server systems (hereinafter referred to as “C / S systems”) that have some functions in client PCs and operate in cooperation with servers have become mainstream.

C/Sシステムは開放系技術を用いているため、各メーカ独自の仕様であったホスト集中型システムと比較して非常に少ない初期投資で構築できるという大きな利点を有し、ホスト集中型システムにとって代わると思われたが、クライアント側にもソフトウェアを導入しなければならない等の理由により、メンテナンス費用も含めた総費用(TCO)の点で、ホスト集中型とあまり変わらないことが判明してきた。   Since the C / S system uses open system technology, it has the great advantage that it can be constructed with very little initial investment compared to the host centralized system that was the original specification of each manufacturer. Although it seemed to be replaced, it has been found that the total cost (TCO) including maintenance costs is not much different from the host-intensive type due to the fact that software must be installed on the client side.

このC/SシステムのTCO増大という問題を解決するため、最近では、オペレーションシステム(OS)に標準で搭載されているインターネットブラウザを使用した3層モデルというものが提案された。これは、「ブラウザ」と称されるとおり閲覧する(ブラウズ)には適しているが、業務処理システムのように入力が主となるものには適しておらず、帳票印刷のような定型フォーマットに印刷する用途にも適していない。また、ネットワーク接続を前提としているため、インターネットに接続できない環境では使用できない等の理由により、企業情報システムとして、ホスト集中型システムやC/Sシステムを完全に置き換えるまでには至っていない。   In order to solve the problem of the increase in TCO of the C / S system, a three-layer model using an Internet browser installed as a standard in an operation system (OS) has been recently proposed. This is suitable for browsing (browsing) as it is called a “browser”, but is not suitable for a main input such as a business processing system, and it is a standard format such as form printing. It is not suitable for printing purposes. Also, since it is premised on network connection, it cannot be completely replaced with a host centralized system or C / S system as a corporate information system because it cannot be used in an environment where it cannot connect to the Internet.

今後は分散環境の発展に伴って、複数のサーバにまたがる分散処理に対し完全性を保証することが要求される。そのためには、通信エラーやサーバのダウン等により、いずれかの処理が実行できなかった場合に、代替処理ができるサーバを探して実行するか、或いは実行済みの処理(例えば、後述のXML Webサービス)に対してキャンセル処理を行うことで処理自体なかったことにするかという複雑な処理を行わなければならない。   In the future, with the development of distributed environments, it is required to guarantee the integrity of distributed processing across multiple servers. To do so, if any process cannot be executed due to a communication error, server down, etc., search for a server that can perform an alternative process, or execute the process (for example, the XML Web service described later). ), It is necessary to perform a complicated process of determining whether the process itself was not performed by performing a cancel process.

ここで、XML Webサービスとは、例えば、下記特許文献1に示されるように、コンピュータシステムで提供されるサービスであって、インターネット上で扱うデータを記述するための新しいデータフォーマット言語であるXML(eXtensible Markup Language)を用いて記述されるものである。XMLによれば、記述された情報に対して「タグ」という独自の意味づけを定義することができるため、プログラムからの操作が容易であり、XML WebサービスのLOGや動的画面を描画するための記述言語としてXMLが使用される。   Here, the XML Web service is, for example, a service provided by a computer system as shown in Patent Document 1 below, and is a new data format language for describing data handled on the Internet, XML ( eXtensible Markup Language). According to XML, it is possible to define a unique meaning of "tag" for the described information, so it is easy to operate from the program, and to draw the XML Web service LOG and dynamic screen XML is used as the description language.

近年のインターネットの普及により24時間365日、場所を問わずに商品を購入できるようになったが、現状のWebサイトは、既存の商売の仕組みをそのままインターネット上に展開したものに過ぎない。すなわち、現在殆どのWebサイトは人間に向かって配信するように設計されている。このため、例えば、旅行や出張に必要な手配をインターネットを用いて行う際には、航空会社や鉄道などの交通機関のWebサイトにアクセスして航空券や乗車券を予約すること、及びホテルのサイトにアクセスして宿泊予約をするというのが通常である。ここで、ホテルが満室なら別ホテルを検索しているなど、顧客自身が旅行代理店の役割を果たしており、顧客の利便性の追及には至っていない。   The spread of the Internet in recent years has made it possible to purchase products 24 hours a day, 365 days a year, regardless of location, but the current Web site is just an existing commercial system on the Internet. That is, most Web sites are now designed to be delivered to humans. For this reason, for example, when making arrangements necessary for travel or business trips using the Internet, it is necessary to access airline and railway websites to make reservations for air tickets and tickets, and It is normal to go to the site and make a reservation. Here, if the hotel is full, the customer himself / herself plays the role of a travel agent, such as searching for another hotel, and the convenience of the customer has not been pursued.

上記のように、現在Webサイトの対象は基本的に人間であるが、今後、XML Webサービスを用いた「次世代Webサイト」を構築すると、Webサイト同士すなわちコンピュータ同士が自立的に結合して連係処理を行うことで、顧客に対するワンストップサービスの提供が可能になり、顧客の利便性がより良くなることが期待される。   As mentioned above, the target of the current website is basically a human being. However, when a “next-generation website” using an XML web service is constructed in the future, websites, that is, computers will be linked independently. By performing the linkage process, it is possible to provide a one-stop service to the customer, and it is expected that the convenience of the customer will be improved.

一方、関連する複数の処理を一つの処理単位としてまとめる「トランザクション」という手法が知られている。これは、例えば金融機関のコンピュータシステムにおける入出金処理のように、一連の作業を全体として一つの処理として管理するために用いる。このトランザクションとして管理された処理は、「すべて成功」か「すべて失敗」のいずれかであることが保証されなければならない。例えば、資金移動システムをコンピュータで処理する場合、出金処理と入金処理は「どちらも成功」か「どちらも失敗」のどちらかであることが要求される。「出金に成功して入金に失敗」すると、出金された資金が宙に浮いてしまうからである。このような場合に、出金と入金をまとめて1つのトランザクションとして管理し、どちらか一方が失敗したら他方も失敗させ、どちらも成功したときに初めて全体を成功と評価するのが「トランザクション処理」である。   On the other hand, a technique called “transaction” is known in which a plurality of related processes are grouped as one processing unit. This is used to manage a series of operations as a single process as a whole, such as a deposit / withdrawal process in a computer system of a financial institution, for example. The process managed as this transaction must be guaranteed to be either “all successful” or “all failed”. For example, when the fund transfer system is processed by a computer, the withdrawal process and the deposit process are required to be either “both successful” or “both failed”. This is because if the withdrawal is successful and the deposit fails, the withdrawn funds will float in the air. In such a case, it is `` transaction processing '' to manage withdrawals and deposits together as one transaction, if one fails, the other fails, and when both succeed, the whole is evaluated as successful It is.

この考え方を応用し、関連する複数のXML Webサービスを一連の作業として全体として一つの処理としたものを、「複数XML Webサービストランザクション」と称する。   Applying this concept, a plurality of related XML Web services are processed as a whole as a single process, and are called “multiple XML Web service transactions”.

特開2004−295898号公報JP 2004-295898 A

従来の技術では、複数のXML Webサービスに跨って完全性を保証するトランザクションを実現する技術は確立されていない。このため、複数XML Webサービスを1トランザクションとして保証し得る手段は提供されていない。   In the conventional technology, a technology for realizing a transaction that guarantees integrity across a plurality of XML Web services has not been established. For this reason, no means is provided that can guarantee multiple XML Web services as one transaction.

本発明の目的は、従来技術の問題点を解決するシステムの構築において基礎となる、複数XML Webサービスの運用に必要なトランザクションの完全性を保証できる手段を提供することである。   An object of the present invention is to provide a means capable of guaranteeing the integrity of transactions necessary for the operation of a plurality of XML Web services, which is the basis for constructing a system that solves the problems of the prior art.

本発明は、複数XML Webサービスの呼出し及び実行処理を一つのトランザクションとして捉え、そのトランザクションに対して完全性を保証する情報処理方法及び装置を提供する。   The present invention provides an information processing method and apparatus for treating invocation and execution processing of a plurality of XML Web services as one transaction and ensuring the integrity of the transaction.

本発明の方法は、インターネット上で利用可能な複数XML Webサービスを利用者に提供するための情報処理方法であって、前記XML Webサービスを実行したとき、キャンセル時に発行する「戻し」のSQL又はパラメータを生成し保存するステップ、及び「戻し」が発生した場合、記録された戻しのSQLやパラメータを用いて、トランザクション自体を取り消すステップを含むことを特徴とする。   The method of the present invention is an information processing method for providing a user with a plurality of XML Web services that can be used on the Internet, and when executing the XML Web service, a “return” SQL issued when canceling or The method includes a step of generating and storing a parameter, and a step of canceling the transaction itself by using the recorded SQL or parameter of the return when a “return” occurs.

本発明の装置は、インターネット上で利用可能なXML Webサービスに関する情報を有する複数のサービス情報提供部から情報の提供を受ける情報処理装置であって、前記複数のサービス情報提供部に対して各々のXML Webサービスを呼び出すとき、一連の処理をキャンセルするための戻しSQL又はパラメータを生成する手段と、いずれかのXML Webサービスが実行付加の場合に前記戻しSQL又はパラメータにより前記一連の処理をキャンセルする手段とを備えたことを特徴とする。   An apparatus of the present invention is an information processing apparatus that receives information from a plurality of service information providing units having information on XML Web services that can be used on the Internet, and each of the plurality of service information providing units When calling an XML Web service, a means for generating a return SQL or parameter for canceling a series of processes, and canceling the series of processes by the return SQL or parameter when any XML Web service is added to execution Means.

上記のように、本発明では、いずれかのXML Webサービスをキャンセルすることが必要になった場合に備えて、XML Webサービスを実行したときに、キャンセル時に発行する「戻し」のSQL (Structured Query Language) やパラメータを自動生成して保存しておく。そして、「戻し」が発生した場合、記録された戻しのSQLやパラメータを使用することにより、トランザクション自体を取り消すことが可能となり、処理全体に対して完全性が保証される。   As described above, in the present invention, in the event that one of the XML Web services needs to be canceled, when the XML Web service is executed, a “return” SQL (Structured Query) issued at the time of cancellation is issued. Language) and parameters are automatically generated and saved. When a “return” occurs, the transaction itself can be canceled by using the recorded return SQL and parameters, and the integrity of the entire process is guaranteed.

ここで、SQLは多くの場合、RDB(リレーショナルデータベース)に格納されている予約情報や顧客情報などのデータを作成・変更・削除するための標準言語として用いられるものであり、上記のXML Webサービス提供側にSQLで記述された命令を受け付ける口を設けることにより、データベースに格納されたデータの自由な操作が可能になる。   Here, SQL is often used as a standard language for creating / changing / deleting data such as reservation information and customer information stored in an RDB (relational database). By providing a port for accepting commands written in SQL on the provider side, data stored in the database can be freely manipulated.

また、SQLを使用すれば、自由にデータの操作が可能になる反面、悪意のあるユーザがSQL命令を発行すると、データの改ざんや消去などが行われてしまうので、SQLでの呼び出しを許さない場合も想定される。そこで、XML Webサービスを呼び出す際にSQLでなく、予約なら1、取消しなら0というようにパラメータで呼び出すことも可能とする。   In addition, if SQL is used, data can be manipulated freely, but if a malicious user issues a SQL command, the data will be altered or erased, so SQL calls are not allowed. Cases are also envisaged. Therefore, when calling an XML Web service, it is possible to call it with parameters such as 1 for reservation and 0 for cancellation instead of SQL.

本発明によれば、複数のXML Webサービスにおいて、全てのXML Webサービスの実行がOKとなった時点で呼び出し元に成功として返す一方、XML Webサービスがどれか一つでもエラーになった場合は、成功したXML Webサービスに対してキャンセル処理を行い、トランザクション自体をなかったことにする。このようなトランザクション環境を構築することにより、インターネットにおいて通信エラーのためXML Webサービスの実行が失敗するといった状況にも対処することができる。   According to the present invention, in a plurality of XML Web services, when the execution of all the XML Web services is OK, it is returned to the caller as success, while any one of the XML Web services results in an error. Suppose that the successful XML Web service is canceled and there is no transaction itself. By constructing such a transaction environment, it is possible to cope with a situation in which execution of the XML Web service fails due to a communication error on the Internet.

上記のように複数のXML Webサービスを1トランザクションとして実現することで、顧客に対するワンストップサービスの実現が可能となり、顧客は様々な利益を享受できる。また、複数のXML Webサービスが仲介する新しいビジネス形態等、様々な利用が期待される。また、通信回線としての専用線やIP−VPN、広域LAN等と比較して安全性や品質が劣るインターネットを用いるコンピュータシステムにおいて、本発明により処理全体の完全性が保証される。   By realizing multiple XML Web services as one transaction as described above, it is possible to realize a one-stop service for customers, and customers can enjoy various benefits. In addition, it is expected to be used in various ways such as new business forms mediated by multiple XML Web services. Further, in a computer system using the Internet, which is inferior in safety and quality as compared with a dedicated line, IP-VPN, wide area LAN or the like as a communication line, the present invention guarantees the integrity of the entire processing.

本発明によれば、各Webサイト同士が自立的に連係処理する仕組みを付与することで、顧客に対するワンストップサービスの実現が可能になる。その仕組みによれば、例えば、顧客が旅行代理店のWebサイトにアクセスして、いつ、どういう目的で、どこへ行きたい、というような漠然とした情報を与えると、顧客の趣味趣向に応じ、必要なWebサイトにアクセスし予約処理を行えるようになる。もし満席や満室の際でも別のWebサイトを検索し、代替案を出してくれるということが可能になり、ユーザにとって利便性は飛躍的に向上する。   According to the present invention, it is possible to realize a one-stop service for a customer by providing a mechanism in which each Web site cooperates independently. According to the mechanism, for example, if a customer accesses a travel agency website and gives vague information such as when, for what purpose, where he wants to go, it is necessary according to the customer's hobbies and preferences. Access to a simple website and make reservations. Even when the seats are full or full, it is possible to search other websites and offer alternatives, which greatly improves convenience for users.

図1は、本発明の技術を適用した複数XML Webサービスを提供するシステムの構成例を示す図である。   FIG. 1 is a diagram illustrating a configuration example of a system that provides a plurality of XML Web services to which the technology of the present invention is applied.

このシステムは、本サービスを利用するユーザ側のクライアント端末(PC)1からネットワーク(例えばインターネット)2を介して接続され、複数XML Webサービスを仲介するサーバ(以下「コーディネートサーバ」という)3と、サービス提供者側の複数のサーバ(以下「エージェントサーバ」という)4a,4b,4c・・・とで構成されている。   This system includes a server (hereinafter referred to as “coordinate server”) 3 that is connected via a network (for example, the Internet) 2 from a client terminal (PC) 1 on the user side that uses this service, and mediates a plurality of XML Web services; It is composed of a plurality of servers (hereinafter referred to as “agent servers”) 4a, 4b, 4c.

クライアント端末1はクライアントエンジン、各サーバはサーバエンジンをそれぞれ備える。この2種のエンジンは、コンピュータプログラムから成り、クライアント端末又は各サーバを構成するコンピュータに格納される。   The client terminal 1 includes a client engine, and each server includes a server engine. These two types of engines are made up of computer programs and stored in a client terminal or a computer constituting each server.

プログラムは、種々の要素の組み合わせにより、ユーザに対してサービスを提供するものである。そこで、このような要素を用意して、各要素の基本的な機能を予め規定しておき、それらの要素を機能させる仕組み(エンジン)を配置することで、現状のプログラムと同等の動作を実現することが考えられる。   The program provides a service to the user by combining various elements. Therefore, by preparing these elements, prescribing the basic functions of each element in advance, and arranging a mechanism (engine) to make those elements function, the operation equivalent to the current program is realized. It is possible to do.

上記エンジン自体を製作するためのプログラミング言語は何でもよく、設定を定義するXMLデータをエンジンの言語に対応させるためにXSL (eXtensible Stylesheet Language) を使用し、プログラミング言語の使用の違いを吸収する。これにより、プログラミング言語ごとにエンジンとXSLのみを作成すれば、あらゆる環境でこの仕組みが実現できる。   Any programming language can be used to create the engine itself, and XSL (eXtensible Stylesheet Language) is used to make the XML data defining the settings correspond to the language of the engine, thereby absorbing differences in the use of the programming language. As a result, if only the engine and XSL are created for each programming language, this mechanism can be realized in any environment.

サーバエンジンは、図2に示すように、クライアント端末1からの処理要求に応じて、サーバ上のWebサービス処理を実行し、結果を回答する。これにより、クライアント端末以外で行う処理をコンピュータ同士が自立的にやり取りして分散処理を実現するXML Webサービスを動的に生成し、複数のXML Webサービスに対して整合性を保った処理環境(トランザクション環境)を提供できる。   As shown in FIG. 2, the server engine executes Web service processing on the server in response to a processing request from the client terminal 1, and replies with the result. As a result, a processing environment that maintains consistency with multiple XML Web services by dynamically generating an XML Web service that realizes distributed processing by autonomously exchanging processing performed by clients other than client terminals ( Transaction environment).

クライアントエンジンは、従来のWebアプリケーションでは不得意な、表現力に乏しいGUI環境を大きく改善するものである。詳細には、次のような機能を有する。   The client engine greatly improves the GUI environment with poor expressiveness, which is not good for conventional Web applications. Specifically, it has the following functions.

通常のクライアント画面はコンパイルしたもの、つまり静的な画面というのが一般的であるが、上記クライアントエンジンでは、画面構成情報からイベント処理等の全てをXMLと呼ばれるタグ言語にて記述し、サーバ側で実行されるXML WebサービスによりXMLで記述された画面構成情報をXML Webサービスから受け取り、その内容を解釈して画面上に動的に描画する。このため、非常に柔軟で表現力に富んだ画面になる一方で、そのやり取りされるXMLの情報量は相当のものになる。   A normal client screen is generally a compiled screen, that is, a static screen. However, in the above client engine, event processing and other information are described in a tag language called XML from the screen configuration information, and the server side The screen configuration information described in XML is received from the XML Web service by the XML Web service executed in, and the contents are interpreted and rendered dynamically on the screen. Therefore, while the screen is very flexible and expressive, the amount of XML information exchanged is considerable.

また、クライアントエンジンでは、画面構成情報からイベント処理など全てをXMLと呼ばれるタグ言語にて記述し、その定義情報から、画面表示の各要素(部品)の表示位置(X,Y座標)や基礎的な表示状態などを動的に再現する。更に、その動作方法及び手順についても、XMLを用いた定義情報から取得して動作させる。これにより、プログラミング作業そのものが変革される。すなわち、プログラマは、プログラムコードを記述するのではなく、プログラムの見栄えや振る舞いに思考の中心を移すことができ、新しいプログラム制作が実現することとなる。   The client engine describes everything from screen configuration information to event processing in a tag language called XML. From the definition information, the display position (X and Y coordinates) and basic information of each element (part) on the screen display Dynamic display state is reproduced dynamically. Further, the operation method and procedure are acquired from definition information using XML and operated. This changes the programming work itself. In other words, the programmer can shift the focus of thinking to the appearance and behavior of the program rather than writing the program code, and a new program can be created.

クライアントエンジンは、図3に示すように、コーディネートサーバ3から複数のクライアント端末1a,1b,1c・・・にそれぞれダウンロードされる。   As shown in FIG. 3, the client engine is downloaded from the coordinate server 3 to a plurality of client terminals 1a, 1b, 1c,.

従って、図4に示すように、コーディネートサーバ3と各種クライアント端末1a,1b,1c・・・との間では次の動作が行われる。
(1)コーディネートサーバ3からクライアントエンジン送信(配布)
(2)クライアント端末1でクライアントアプリケーションの生成
(3)クライアント端末1からWebサービス(予約など)要求
(4)コーディネートサーバ3からエージェントサーバ4へWebサービス呼出し及び実行
(5)エージェントサーバ4からのWebサービス実行処理結果をクライアント側へ送信。
Therefore, as shown in FIG. 4, the following operation is performed between the coordinate server 3 and the various client terminals 1a, 1b, 1c.
(1) Client engine transmission from distribution server 3 (distribution)
(2) Generation of client application at client terminal 1 (3) Web service (reservation etc.) request from client terminal 1 (4) Call and execution of Web service from coordinate server 3 to agent server 4 (5) Web from agent server 4 Send service execution processing results to the client side.

図1のシステムは、サーバエンジンにより、複数XML Webサービスに対して完全性を保証する仕組みを構築している。すなわち、複数Webサービストランザクションにより、顧客に対するワンストップサービスを実現させるため各WebサイトにXML Webサービスという自立的に動くエージェントサーバを配置し、そのエージェントにて空席状況の確認や予約処理などを行うこと、及び各エージェントを統括する仕組みが提供される。   The system shown in FIG. 1 uses a server engine to construct a mechanism that guarantees the integrity of multiple XML Web services. In other words, in order to realize a one-stop service for customers with multiple Web service transactions, an autonomously moving agent server called XML Web Service is placed on each Web site, and vacant seat status confirmation and reservation processing etc. are performed at that agent. And a mechanism for supervising each agent.

例えば、1泊2日で地方から東京への出張の手配をする状況を考えてみると、交通手段の確保と宿泊先の確保が最低限必要であり、そのいずれか一つでも確保できなかった場合は、出張手配としては成立しない。これを人間の手を介さずにコンピュータで処理を完結させるためには、次のような仕組みが必要である。
(1) Webサイト(航空会社、ホテル等)で提供するXML Webサービスをコーディネートする機能。
(2) 顧客に対して完全な状態で予約を提供することは勿論、各Webサイトにて存在しない予約が入ることを避けるために、いずれかの予約が成立しなかった場合は予約処理自体をなかったことにすることで、取引全体に対して完全性を提供するための仕組み。
For example, considering the situation of making a business trip from the region to Tokyo in 2 days and 1 night, it is necessary to secure transportation and secure accommodation, at least one of which could not be secured. In this case, it will not be established as a business trip arrangement. In order to complete this processing with a computer without human intervention, the following mechanism is required.
(1) A function to coordinate XML Web services provided on Web sites (airlines, hotels, etc.).
(2) In order to avoid making reservations that do not exist on each website, as well as providing reservations to customers in perfect condition, if any reservation is not established, the reservation process itself is performed. A mechanism for providing completeness to the entire transaction by not having.

図1のシステムは、例えば、一般ユーザが旅行や出張に必要な手配をする場合、図5に示すように、ユーザ自身が携帯電話やパソコンなどの端末11からインターネット12を介して、航空会社や鉄道などの交通機関、宿泊したいホテルや旅館及び観光地の施設などのWebサイト13a,13b,13cにアクセスして各々予約をするといった手間を解消するため、図6に示すように、上記サーバエンジンを備えたコーディネートサーバ3が旅行代理店の役割を果たすシステムとして利用できる。図6のシステム構成では、各Webサイト13a,13b,13cを運営する事業者に、図1の各エージェントサーバ4a,4b,4cが設置される。   In the system of FIG. 1, for example, when a general user makes necessary arrangements for a trip or a business trip, as shown in FIG. 5, the user himself / herself from a terminal 11 such as a mobile phone or a personal computer via the Internet 12 In order to eliminate the trouble of making reservations by accessing the websites 13a, 13b, and 13c such as transportation facilities such as railroads, hotels, inns, and sightseeing spot facilities to be stayed, as shown in FIG. Can be used as a system that plays the role of a travel agency. In the system configuration of FIG. 6, the agent servers 4a, 4b, and 4c of FIG. 1 are installed in the business operators that operate the Web sites 13a, 13b, and 13c.

旅行代理店としてのXML Webサービスは、複数の異なるXML Webサービスを仲介するものと考えられる。この場合、システムは、図7に示すように、ユーザ端末11からの予約リクエストに応じて予約サービスを仲介するコーディネートサーバ3と、ホテル予約、レンタカー予約、航空券予約、その他の予約サービスを提供するエージェントサーバ4a,4b,4c,4dと、ユーザ端末11とコーディネートサーバ3の間及びコーディネートサーバ3と各エージェントサーバ4a,4b,4c,4dの間をそれぞれ接続するインターネット(図示省略)とで構成される。コーディネートサーバ3は、変更内容をXMLで書き込むためのメモリ31を備えている。   An XML Web service as a travel agent is considered to mediate several different XML Web services. In this case, as shown in FIG. 7, the system provides a coordination server 3 that mediates a reservation service in response to a reservation request from the user terminal 11, a hotel reservation, a rental car reservation, an airline ticket reservation, and other reservation services. The agent server 4a, 4b, 4c, 4d, and the Internet (not shown) that connects between the user terminal 11 and the coordinate server 3, and between the coordinate server 3 and each agent server 4a, 4b, 4c, 4d, respectively. The The coordinate server 3 includes a memory 31 for writing the change contents in XML.

このシステムでは、コーディネートサーバ3は、ユーザ端末11から予約リクエストを受けると、それに応じた予約サービスを実行するエージェントサーバ4a,4b,4c又は4dへ予約リクエストを送り、そのエージェントサーバから予約OKの返答を受けると、返答をユーザ端末11へ送る。ユーザ端末11からの予約リクエストに対し、その要求に係る全ての予約処理が完了するまで予約リクエストを受けないようにサーバをロックすることとなる。しかしながら、旅行代理店としてのXML Webサービスでは、従来のトランザクション(コンピュータでの処理)のように全ての処理が完了するまでサーバのコンピュータ資源をロックすることは困難である。   In this system, when the coordinating server 3 receives a reservation request from the user terminal 11, it sends a reservation request to the agent server 4a, 4b, 4c or 4d that executes the reservation service corresponding to the reservation request, and the agent server returns a reservation OK response. In response, a response is sent to the user terminal 11. In response to a reservation request from the user terminal 11, the server is locked so as not to receive the reservation request until all the reservation processes related to the request are completed. However, in the XML Web service as a travel agency, it is difficult to lock the computer resources of the server until all processing is completed as in the conventional transaction (computer processing).

そこで、いずれかの予約処理の結果が“NG”の場合(例えば、ユーザの希望する交通機関が満席である場合)は、代替策を検索するとしても、以下のキャンセル処理を行うことで処理自体をなかったことにすれば、トランザクションの完全性を保証できる。すなわち、図8に示すように、コーディネートサーバ3は、ユーザ端末11からの予約リクエストにより旅行代理店XML Webサービスを起動し、予約リクエストをエージェントサーバ4a,4b,4c,4dに送ることで、予約に必要なXML Webサービスを呼び出す。その際、キャンセル処理のための戻しロジック(「戻し」のSQL)を自動生成し、LOGとしてメモリ31に保管しておく。そして、各エージェントサーバでの実行結果を集計、判定し、全ての予約処理がOK(成功)ならば、トランザクションは終了し、OKの返答をユーザ端末11へ送る。他方、いずれかの処理がNG(不成功)ならば、XML Webサービス・キャンセル処理を行い、成功したXML Webサービスに対して実行しなかったことにする。そして、予約不成功の返答をユーザ端末11に送る。   Therefore, if the result of any reservation processing is “NG” (for example, if the user's desired transportation system is full), even if searching for an alternative measure, the processing itself is performed by performing the following cancellation processing. If you didn't, you can guarantee transaction integrity. That is, as shown in FIG. 8, the coordination server 3 activates the travel agency XML Web service in response to a reservation request from the user terminal 11, and sends a reservation request to the agent servers 4a, 4b, 4c, and 4d. Call the XML Web service required for. At this time, a return logic (“Return” SQL) for cancel processing is automatically generated and stored in the memory 31 as a LOG. Then, the execution results in each agent server are totaled and determined, and if all the reservation processes are OK (success), the transaction ends and an OK response is sent to the user terminal 11. On the other hand, if any of the processes is NG (unsuccessful), the XML Web service cancel process is performed, and it is determined that the successful XML Web service is not executed. Then, a reservation failure response is sent to the user terminal 11.

図9は、コーディネートサーバとエージェントサーバによる複数XML Webサービスの処理手順を示すフローチャートである。   FIG. 9 is a flowchart showing a processing procedure of a plurality of XML Web services by the coordinate server and the agent server.

初めにコーディネートサーバは、予約リクエストの有無をチェックし(ST1)、予約リクエストがあるとき、XML Webサービスを呼び出し、その予約リクエストに応じたサービスの種類(範囲)を確定する(ST2)。同時に、「戻し」のSQLメッセージ又はパラメータを自動生成して、メモリ31に保存する(ST3)。   First, the coordinating server checks whether there is a reservation request (ST1), and when there is a reservation request, calls the XML Web service and determines the type (range) of the service corresponding to the reservation request (ST2). At the same time, a “return” SQL message or parameter is automatically generated and stored in the memory 31 (ST3).

例えば、SQLメッセージの場合は、insert文ならdelete文を、update文なら元のデータを戻すため、現在のデータをselectで取得し、「戻し」のためのupdate文を自動生成してLOGとして格納する。「戻し」のSQLについては、後で具体例を説明する。   For example, in the case of an SQL message, the delete statement is used for the insert statement, and the original data is returned for the update statement, so the current data is acquired with select, and the update statement for "return" is automatically generated and stored as LOG To do. A specific example of “return” SQL will be described later.

他方、パラメータ受け渡しの場合は、実行したXML Webサービスからキャンセル処理のための「戻し」パラメータを取得してLOGとして格納する。   On the other hand, in the case of parameter passing, a “return” parameter for cancel processing is acquired from the executed XML Web service and stored as LOG.

次に、上記で確定した範囲のXML Webサービスを呼び出す(ST4)。すなわち、当該XML Webサービスを実行するエージェントサーバに予約リクエストを送信する。   Next, the XML Web service in the range determined above is called (ST4). That is, a reservation request is transmitted to the agent server that executes the XML Web service.

各エージェントサーバでは、受信した予約リクエストに応じて、所定のXML Webサービス(予約)処理を実行し(ST11)、その処理結果をコーディネートサーバに送信する(ST12)。   Each agent server executes a predetermined XML Web service (reservation) process in response to the received reservation request (ST11), and transmits the processing result to the coordination server (ST12).

コーディネートサーバでは、受信したサービス処理結果をメモリに格納し(ST5)、処理結果が全てOKか否かを判定する(ST6)。その結果“Yes”であれば、予約リクエストを送ったユーザ端末に「予約成功」の結果通知を送信して(ST7)、サービス終了となる。   The coordinate server stores the received service processing result in the memory (ST5), and determines whether all the processing results are OK (ST6). If the result is “Yes”, a result notification of “reservation success” is transmitted to the user terminal that has sent the reservation request (ST7), and the service is terminated.

一方、ST6の判定結果が“No”、すなわち複数XML WebサービスのどれかがNGの場合は、代替案の有無すなわち他のサービスの予約が可能かどうかをチェックし(ST8)、“Yes”であれば、代替案のXML Webサービスを呼び出す(ST9)。すなわち、そのXML Webサービスを実行するエージェントサーバに予約リクエストを送信する。   On the other hand, if the determination result in ST6 is “No”, that is, if any of the plurality of XML Web services is NG, it is checked whether there is an alternative, that is, whether other services can be reserved (ST8). If there is, the alternative XML Web service is called (ST9). That is, a reservation request is transmitted to the agent server that executes the XML Web service.

当該エージェントサーバでは、受信した予約リクエストに応じて、その代替案サービス(予約)処理を実行し(ST13)、その処理結果をコーディネートサーバに送信する(ST14)。   The agent server executes the alternative service (reservation) process in response to the received reservation request (ST13), and transmits the processing result to the coordinate server (ST14).

コーディネートサーバでは、受信した代替案サービス処理結果をメモリに格納し(ST5)、以下の手順を繰り返す。上記ST8の判定で“No”、すなわち代替案がない場合は、メモリ31に格納した「戻し」のSQLメッセージ又はパラメータを使用して、成功したXML Webサービスに対して実行しなかったことにするキャンセル呼出し指令を各エージェントサーバに送る(ST10)。   The coordinate server stores the received alternative service processing result in the memory (ST5), and repeats the following procedure. If the determination in ST8 is “No”, that is, if there is no alternative, it is determined that the execution has not been executed for a successful XML Web service using the “return” SQL message or parameter stored in the memory 31. A cancel call command is sent to each agent server (ST10).

各エージェントサーバでは、キャンセル呼出し指令に応じて、XML Webサービス(キャンセル)処理を実行し(ST15)、その処理結果をコーディネートサーバに送信する(ST16)。   Each agent server executes XML Web service (cancel) processing in response to the cancel call command (ST15), and transmits the processing result to the coordinate server (ST16).

コーディネートサーバでは、予約リクエストを送ったユーザ端末に「予約不成功」の結果通知を送信して(ST7)、サービス終了となる。   The coordinate server transmits a notification of “reservation unsuccessful” to the user terminal that has sent the reservation request (ST7), and the service ends.

ここで、上記のようにサーバで自動生成されるSQLについて説明する。   Here, SQL generated automatically by the server as described above will be described.

(1) レコードを追加するSQL(INSERT):
例えば、“INSERT 項目名A(ユニークキー),項目名B,項目名C, 項目名D FROM TABLE名”ならば、戻しのSQLとして、
DELETE FROM TABLE名WHERE 項目名A = '削除キー '
というSQLを自動生成する。キャンセル処理の際には、このSQLを実行する。
(1) SQL to add records (INSERT):
For example, if "INSERT item name A (unique key), item name B, item name C, item name D FROM TABLE name",
DELETE FROM TABLE name WHERE item name A = 'delete key'
Automatically generates SQL. This SQL is executed when canceling.

(2) レコードを変更するSQL(UPDATE):
例えば、“UPDATE TABLE名 SET 項目名B=変更値 , 項目名C=変更値 , 項目名D=変更値 WHERE 項目名A=変更キー”のように、B,C,Dを変更するSQLを発行しようとする際には、
SELECT * FROM TABLE名WHERE 項目名 =変更キー
というSQLを発行して、事前に変更前の項目情報を取得する。そして、
“UPDATE TABLE名 SET 項目名B=変更値 , 項目名C=変更値 , 項目名D=変更値 WHERE 項目名A=変更キー”
というSQLを自動生成する。「戻し」が発生した場合は、このSQLを実行する。
(2) SQL to change records (UPDATE):
For example, issue SQL to change B, C, and D, such as “UPDATE TABLE name SET item name B = change value, item name C = change value, item name D = change value WHERE item name A = change key” When trying to
SELECT * FROM TABLE name WHERE Issue item name = change key SQL and obtain the item information before change in advance. And
“UPDATE TABLE name SET item name B = change value, item name C = change value, item name D = change value WHERE item name A = change key”
Automatically generates SQL. If "return" occurs, execute this SQL.

一例として、新規にホテルを予約したい場合を考える。その場合のSQLは、
“INSERT 予約番号,名前,宿泊日,泊数,部屋タイプ, FROM 予約テーブル”となる。
As an example, consider a case where a new hotel reservation is desired. The SQL in that case is
“INSERT reservation number, name, date of stay, number of nights, room type, FROM reservation table”.

この予約SQLの発行と同時に、予約自体を取り消す戻しSQLとして、
“DELETE FROM予約テーブルWHERE予約番号=予約番号”
を自動生成してLOGに格納する。
At the same time as issuing this reservation SQL, as a return SQL to cancel the reservation itself,
“DELETE FROM reservation table WHERE reservation number = reservation number”
Is automatically generated and stored in LOG.

その後、ホテルでの予約内容の変更が発生した場合は、
“SELECT * FROM予約テーブルWHERE予約番号=予約番号”
というSQLを発行して、事前に変更前の項目情報を取得しておく。そして、
“UPDATE 予約テーブル SET 名前=名前(変更前) , 宿泊日=宿泊日(変更前) , 泊数=泊数(変更前) , 部屋タイプ=部屋タイプ(変更前) WHERE 予約番号=予約番号(ユニークキー)”
というSQLを発行して、LOGに格納する。
Later, if there is a change in the reservation details at the hotel,
“SELECT * FROM reservation table WHERE reservation number = reservation number”
Issue the SQL to obtain the item information before the change in advance. And
“UPDATE reservation table SET name = name (before change), stay date = night (before change), number of nights = night (before change), room type = room type (before change) WHERE reservation number = reservation number (unique) Key)"
Is issued and stored in LOG.

「戻し」が発生した場合は、上記SQLを実行することで、更新前のデータに戻すことが可能になる。   When "return" occurs, it is possible to return to the data before update by executing the above SQL.

図10は、WebサービストランザクションLOGの例を示す。LOG自体はXMLで記述し、プログラムにて扱いやすい形態とする。勿論、XMLでないデータフォーマットでも記述可能である。   FIG. 10 shows an example of the Web service transaction LOG. The LOG itself is described in XML and is easy to handle in the program. Of course, it can be described in a data format other than XML.

図のように、取引単位をトランザクションとし、「トランザクション名」として唯一固有の数字を割り振る(2行目)。そのトランザクションにて呼び出したXML Webサービス名を記述し(3行目)、自動生成したSQLもしくはパラメータと実行結果を記述する(4〜5行目)。他にも呼び出したXML Webサービスがあれば、同様に記述する(6行目以降)。   As shown in the figure, the transaction unit is a transaction, and a unique number is assigned as the “transaction name” (second line). Describe the name of the XML Web service called in the transaction (line 3), and describe the automatically generated SQL or parameter and execution result (line 4-5). If there are other XML Web services that have been called, they are described in the same way (from the sixth line).

サーバエンジンは、複数のXML Webサービスの実行状況をLOGに随時記録しながら、キャンセル時にはLOGを参照しながらキャンセル処理を発行する。これにより、複数XML Webサービスの実行に関して完全性を保障するトランザクション処理を実現している。   The server engine issues a cancellation process while referring to the LOG when canceling, while recording the execution status of multiple XML Web services as needed. This enables transaction processing that guarantees the integrity of the execution of multiple XML Web services.

上記のシステムによれば、図11に示すように、旅行代理店21にコーディネートサーバを設置し、予約を受け付けるホテル22、鉄道会社23、航空会社24に各エージェントサーバをそれぞれ設置することにより、旅行代理店からホテルや各交通機関の予約をとるサービスが提供される。それは、図9の処理手順に従って、例えば次のように行われる。
(1)旅行代理店21のサーバからホテル22のサーバに予約リクエストを送る。
(2)予約が成功すると、ホテル22から旅行代理店21にOKの返答を送る。
(3)旅行代理店21のサーバから鉄道会社23のサーバに指定券の予約リクエストを送る。
(4)予約が成功すると、鉄道会社23から旅行代理店21にOKの返答を送る。
(5)旅行代理店21のサーバから航空会社24のサーバに座席の予約リクエストを送る。
(6)座席が取れない場合、航空会社24から旅行代理店21にNGの返答を送る。
(7)この場合、補償トランザクションとして、旅行代理店21のサーバからホテル22のサーバにキャンセルのリクエストを送る。
(8)同時に、旅行代理店21のサーバから鉄道会社23のサーバにキャンセルのリクエストを送る。
According to the above system, as shown in FIG. 11, a coordinate server is installed in the travel agency 21, and agent servers are installed in the hotel 22, the railway company 23, and the airline 24 that accept reservations. A service is provided to make reservations for hotels and transportation facilities from agents. This is performed, for example, as follows in accordance with the processing procedure of FIG.
(1) A reservation request is sent from the travel agency 21 server to the hotel 22 server.
(2) When the reservation is successful, the hotel 22 sends an OK response to the travel agency 21.
(3) A reservation ticket reservation request is sent from the travel agency 21 server to the railway company 23 server.
(4) When the reservation is successful, the railway company 23 sends an OK response to the travel agency 21.
(5) A seat reservation request is sent from the server of the travel agency 21 to the server of the airline 24.
(6) If the seat cannot be taken, an NG response is sent from the airline 24 to the travel agent 21.
(7) In this case, a cancellation request is sent from the server of the travel agency 21 to the server of the hotel 22 as a compensation transaction.
(8) At the same time, a cancellation request is sent from the server of the travel agency 21 to the server of the railway company 23.

上記のようにユーザからの予約リクエストに応じて、予約サービスを実行し、希望に適った予約がなかった場合は代替案を提示する処理によれば、ユーザ端末の表示画面には、予約リクエスト送信時及び処理結果回答時に、次のような表示がなされる。   As described above, according to the reservation request from the user, the reservation service is executed, and when there is no reservation that meets the request, an alternative is presented. At the time and when processing results are answered, the following display is made.

例えば、ユーザが金沢から東京・赤坂に出張し1泊したい場合は、図12に示すように、ユーザ端末から出発日、到着時間、帰着日、出発時間、出発地、目的地、交通手段、宿泊希望地、費用の各希望条件を入力すると、予約リクエストの内容が、図12の左側の画面に示すように表示される。この内容で、予約リクエストがコーディネートサーバに送信され、希望の予約サービスを提供するエージェントサーバでの処理により、条件符合(予約OK)の場合は、予約処理の結果が、図12の右上の画面に示すように表示され、条件不符合(例えば、帰りの航空便予約がNG)の場合は、OKとなった予約と共にNGとなった予約の代替案が、図12の右下の画面に示すように表示される。これにより、ユーザは代替案を直ちに選択できる。   For example, if the user wants to make a business trip from Kanazawa to Tokyo / Akasaka for one night, as shown in FIG. 12, the departure date, arrival time, return date, departure time, departure location, destination, transportation, accommodation from the user terminal When the desired conditions of the desired place and expense are entered, the contents of the reservation request are displayed as shown on the screen on the left side of FIG. With this content, a reservation request is transmitted to the coordination server, and if the condition is a match (reservation OK) by processing at the agent server that provides the desired reservation service, the result of the reservation process is displayed on the upper right screen of FIG. If the condition is not met (for example, the return flight reservation is NG), an alternative to the NG reservation along with the OK reservation is shown in the lower right screen of FIG. Is displayed. This allows the user to select an alternative immediately.

最後に、図1のシステムでは、ネットワークを介して通信するクライアント端末やXML Webサービスを提供するサーバの間の通信を高速化するための手段(「高速通信コンポーネント」と称する)を、クライアント端末及び各サーバに設けている。高速通信コンポーネントは、XML Webサービス実行のために必要なファイルやデータを圧縮、分割して送信する機能と、他から受信した分割ファイル等を結合、解凍してXML Webサービス処理を実行する機能とを備えたソフトウェアから成る。   Finally, in the system of FIG. 1, means for speeding up communication between a client terminal that communicates via a network and a server that provides an XML Web service (referred to as a “high-speed communication component”) It is provided in each server. The high-speed communication component has a function to compress and divide and transmit files and data necessary for executing XML Web services, and a function to execute XML Web service processing by combining and decompressing divided files received from others. Consists of software with

各サーバ又はクライアント端末は、この高速通信コンポーネントにより、図13に示すように、(1) XML Webサービス呼出し手順を圧縮し、(2) 分割し、(3) 分割した個々の情報を同時にネットワークを介して送信する。また、他のサーバからネットワークを介して、(4) 分割された情報を受信すると、(5) それらを結合し、(6) 解凍して、XML Webサービス処理を実行する。   As shown in FIG. 13, each server or client terminal uses this high-speed communication component to (1) compress the XML Web service call procedure, (2) divide, and (3) simultaneously divide each piece of information into the network. Send through. When (4) the divided information is received from another server via the network, (5) they are combined, (6) are decompressed, and the XML Web service process is executed.

上記高速通信コンポーネントによれば、多数のリスエストを効率よく処理することができ、XML Webサービスのレベル向上に大きく寄与する。   According to the above high-speed communication component, a large number of requests can be processed efficiently, which greatly contributes to improving the level of XML Web services.

以上、本発明の実施の形態として、旅行代理店としてのサービスを行うシステムについて説明したが、本発明はこれに限らず、複数XML Webサービスを提供するシステムに適用できる。   As described above, a system for providing a service as a travel agency has been described as an embodiment of the present invention. However, the present invention is not limited to this, and can be applied to a system that provides a plurality of XML Web services.

本発明の技術を適用した複数XML Webサービス提供システムの構成図。The block diagram of the multiple XML Web service provision system to which the technique of this invention is applied. コーディネートサーバから各クライアント端末にクライアントエンジンがダウンロードされることを示す図。The figure which shows that a client engine is downloaded from a coordination server to each client terminal. クライアント端末からの処理要求に応じてWebサービス処理を実行し、結果を回答するサーバエンジンを示す図。The figure which shows the server engine which performs a Web service process according to the process request from a client terminal, and answers a result. ネットワークを介して通信する各クライアント端末とコーディネートサーバとを示す図。The figure which shows each client terminal and coordinate server which communicate via a network. ユーザ端末からインターネットを介して各Webサイトにアクセスし各々予約をする場合の説明図。Explanatory drawing when each Web site is accessed from the user terminal via the Internet and each reservation is made. サーバエンジンを備えたコーディネートサーバが旅行代理店の役割を果たすシステムの構成図。The block diagram of the system by which the coordination server provided with the server engine plays the role of a travel agency. 旅行代理店として複数の異なるXML Webサービスを仲介するシステムの構成図。The block diagram of the system which mediates several different XML Web services as a travel agency. 予約処理の結果によりキャンセル処理を行うシステムの構成図。The block diagram of the system which performs a cancellation process by the result of a reservation process. コーディネートサーバとエージェントサーバによる複数XML Webサービスの処理手順を示すフローチャート。The flowchart which shows the process sequence of multiple XML Web service by a coordination server and an agent server. WebサービストランザクションLOGの例を示す図。The figure which shows the example of Web service transaction LOG. 旅行代理店からホテルや各交通機関への予約サービスを行うシステムの構成図。The block diagram of the system which performs the reservation service from a travel agency to a hotel and each transportation system. 予約サービス処理によりユーザ端末の画面に表示される内容の例を示す図。The figure which shows the example of the content displayed on the screen of a user terminal by a reservation service process. 高速通信コンポーネントによる信号処理手順を示す図。The figure which shows the signal processing procedure by a high-speed communication component.

符号の説明Explanation of symbols

1…クライアント端末、2…ネットワーク、3…コーディネートサーバ、4a,4b,4c…エージェントサーバ、11…ユーザ端末、12…インターネット、13a,13b,13c…Webサイト、21…旅行代理店、22…ホテル、23…鉄道会社、24…航空会社。

DESCRIPTION OF SYMBOLS 1 ... Client terminal, 2 ... Network, 3 ... Coordinate server, 4a, 4b, 4c ... Agent server, 11 ... User terminal, 12 ... Internet, 13a, 13b, 13c ... Web site, 21 ... Travel agency, 22 ... Hotel , 23 ... railway company, 24 ... airline.

Claims (2)

インターネット上で利用可能な複数のXML Webサービスを利用者に提供するための情報処理方法において、
前記XML Webサービスを呼び出して、SQLメッセージを実行するとき、前記SQLメッセージに含まれるSQL文がinsert文である場合には、前記insert文を無効化するための戻しdelete文からなるSQLメッセージを生成し、前記SQLメッセージに含まれるSQL文がupdate文である場合には、前記update文による変更前の状態に戻すための戻しupdate文からなるSQLメッセージを生成し、生成された前記戻しdelete文又は前記戻しupdate文からなる戻しSQLメッセージをこのXML Webサービスに関連付けて保存するステップ、及び
前記XML Webサービスをキャンセルする場合、このXML Webサービスに関連付けて記録された、前記戻しSQLメッセージを用いて、トランザクション自体を取り消すステップ
を含むことを特徴とする情報処理方法。
In an information processing method for providing users with multiple XML Web services that can be used on the Internet,
When executing the SQL message by calling the XML Web service, if the SQL statement included in the SQL message is an insert statement, an SQL message consisting of a return delete statement for invalidating the insert statement is generated. When the SQL statement included in the SQL message is an update statement, an SQL message including a return update statement for returning to the state before the change by the update statement is generated, and the generated return delete statement or A step of storing a return SQL message composed of the return update statement in association with the XML Web service, and when canceling the XML Web service, using the return SQL message recorded in association with the XML Web service, An information processing method comprising a step of canceling a transaction itself.
インターネット上で利用可能なXML Webサービスに関する情報を有する複数のサービス情報提供部から情報の提供を受ける情報処理装置であって、
前記複数のサービス情報提供部に対して各々のXML Webサービスを呼び出して、SQLメッセージを実行するとき、前記SQLメッセージに含まれるSQL文がinsert文である場合には、前記insert文を無効化するための戻しdelete文からなるSQLメッセージを生成し、前記SQLメッセージに含まれるSQL文がupdate文である場合には、前記update文による変更前の状態に戻すための戻しupdate文からなるSQLメッセージを生成し、生成された前記戻しdelete文又は前記戻しupdate文からなる戻しSQLメッセージをこのXML Webサービスに関連付けて保存する手段と、
いずれかのXML Webサービスが実行不可の場合に、このXML Webサービスに関連付けて記録された前記戻しSQLメッセージを用いて、前記一連の処理をキャンセルする手段と
を備えたことを特徴とする情報処理装置。
An information processing apparatus that receives information from a plurality of service information providing units having information on XML Web services that can be used on the Internet,
When each XML Web service is called for the plurality of service information providing units and an SQL message is executed, if the SQL statement included in the SQL message is an insert statement, the insert statement is invalidated If the SQL message included in the SQL message is an update statement, an SQL message consisting of a return update statement for returning to the state before the change by the update statement is generated. Means for generating and storing the generated return SQL message comprising the return delete statement or the return update statement in association with the XML Web service;
An information processing system comprising: means for canceling the series of processes using the return SQL message recorded in association with the XML Web service when any XML Web service is not executable apparatus.
JP2004377409A 2004-12-27 2004-12-27 Information processing method and apparatus Expired - Fee Related JP4403065B2 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
JP2004377409A JP4403065B2 (en) 2004-12-27 2004-12-27 Information processing method and apparatus

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
JP2004377409A JP4403065B2 (en) 2004-12-27 2004-12-27 Information processing method and apparatus

Related Child Applications (1)

Application Number Title Priority Date Filing Date
JP2009069227A Division JP2009176310A (en) 2009-03-22 2009-03-22 Information processing method and apparatus

Publications (2)

Publication Number Publication Date
JP2006185125A JP2006185125A (en) 2006-07-13
JP4403065B2 true JP4403065B2 (en) 2010-01-20

Family

ID=36738199

Family Applications (1)

Application Number Title Priority Date Filing Date
JP2004377409A Expired - Fee Related JP4403065B2 (en) 2004-12-27 2004-12-27 Information processing method and apparatus

Country Status (1)

Country Link
JP (1) JP4403065B2 (en)

Families Citing this family (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP5385545B2 (en) * 2008-04-17 2014-01-08 インターナショナル・ビジネス・マシーンズ・コーポレーション Apparatus and method for controlling execution of transaction
JP2010282586A (en) * 2009-06-08 2010-12-16 Fujitsu Ltd Device, method and program for managing file, and information system

Also Published As

Publication number Publication date
JP2006185125A (en) 2006-07-13

Similar Documents

Publication Publication Date Title
US9256655B2 (en) Dynamic access of data
CN100357929C (en) System and method for transaction processing with delegated commit feature
US7346667B2 (en) System for delivering dynamic content
US7716347B2 (en) Method for managing commerce contexts
CN101583938A (en) Systems and methods of transforming data for web communities and web applications
WO2007028160A2 (en) Database system and method for access control and workflow routing
JP2004538574A (en) Workflow system capable of document version management and document version management method using the same
CN102262674A (en) Data synchronization method and system for distributed memory database
US7328222B2 (en) Method and apparatus for preserving data coherency in a database by generating a command object that includes instructions for writing a data record to a local cache
CN109739827A (en) A kind of block chain storage system based on double-strand framework
KR20140012663A (en) System and method for session synchronization with independent external systems
Goecke The evolution of online booking systems
US20040015422A1 (en) Ministry specialized insurance transaction object oriented system and method
JP4665042B2 (en) Dynamic access of data
JP4403065B2 (en) Information processing method and apparatus
JP2009176310A (en) Information processing method and apparatus
JP4262655B2 (en) Workflow system and workflow system management method
JP5693638B2 (en) Communication relay system with split / combine functions such as XML tags
US20050278640A1 (en) System and method of dynamic entitlement
JP2002298059A (en) Settlement control system and settlement control program
JP2008129872A (en) Conference system server and conference method
JPH1196054A (en) System for constructing data base integrating application
JP2002189842A (en) Workflow management control system and method, and recording medium recording workflow management control program
JP2000137682A (en) Access controller and medium for recording its program
CN117319081A (en) System and method for sharing data in same system

Legal Events

Date Code Title Description
RD03 Notification of appointment of power of attorney

Free format text: JAPANESE INTERMEDIATE CODE: A7423

Effective date: 20060403

A621 Written request for application examination

Free format text: JAPANESE INTERMEDIATE CODE: A621

Effective date: 20060405

RD02 Notification of acceptance of power of attorney

Free format text: JAPANESE INTERMEDIATE CODE: A7422

Effective date: 20060913

RD02 Notification of acceptance of power of attorney

Free format text: JAPANESE INTERMEDIATE CODE: A7422

Effective date: 20071119

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A821

Effective date: 20071119

A621 Written request for application examination

Free format text: JAPANESE INTERMEDIATE CODE: A621

Effective date: 20071226

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20080425

A131 Notification of reasons for refusal

Free format text: JAPANESE INTERMEDIATE CODE: A131

Effective date: 20090120

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20090323

A02 Decision of refusal

Free format text: JAPANESE INTERMEDIATE CODE: A02

Effective date: 20090525

A521 Request for written amendment filed

Free format text: JAPANESE INTERMEDIATE CODE: A523

Effective date: 20090824

A911 Transfer to examiner for re-examination before appeal (zenchi)

Free format text: JAPANESE INTERMEDIATE CODE: A911

Effective date: 20091001

TRDD Decision of grant or rejection written
A01 Written decision to grant a patent or to grant a registration (utility model)

Free format text: JAPANESE INTERMEDIATE CODE: A01

Effective date: 20091019

A01 Written decision to grant a patent or to grant a registration (utility model)

Free format text: JAPANESE INTERMEDIATE CODE: A01

A61 First payment of annual fees (during grant procedure)

Free format text: JAPANESE INTERMEDIATE CODE: A61

Effective date: 20091030

R150 Certificate of patent or registration of utility model

Free format text: JAPANESE INTERMEDIATE CODE: R150

FPAY Renewal fee payment (event date is renewal date of database)

Free format text: PAYMENT UNTIL: 20121106

Year of fee payment: 3

FPAY Renewal fee payment (event date is renewal date of database)

Free format text: PAYMENT UNTIL: 20131106

Year of fee payment: 4

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

R250 Receipt of annual fees

Free format text: JAPANESE INTERMEDIATE CODE: R250

LAPS Cancellation because of no payment of annual fees