Cyber LuxeonのDBアクセス制御
本章では、Cyber Luxeonへの接続形態の種類、そしてDBトランザクションについて説明します。アプリケーション開発時には、これらのCyber Luxeonの特徴をよくおさえておく必要があるでしょう。
Cyber Luxeonとの接続形態(セッション)
Cyber Luxeonでは、接続を表す概念としてセッション(Session)が使用されます。セッションは、クライアントセッションとローカルセッションの2種類が用意されています。Java APIでは、Sessionインターフェイス(com.exln.dxe)で表現されます。SessionインターフェイスはRDBアクセスに用いるJDBCのjava.sql.Connectionインターフェイスに相当します。2種類のセッションの概念を以下の図に示します。
クライアントセッションとローカルセッションの特徴を以下の表にまとめました。
セッション | 接続先 | 用途 |
クライアントセッション | リモートホストのキャッシュプロセス | Webアプリケーションなど分散アプリケーション |
ローカルセッション | ローカルホストのDXE ObjectStoreサーバ | 大量データ処理等、負荷の高い処理 |
本稿のサンプルアプリケーションは、クライアントセッションを使用します。クライアントセッションを使用する理由としては、本稿のサンプルがWebアプリケーションであるためです。Cyber Luxeonの大きな特徴として、XMLキャッシュの分散配置(分散キャッシュ)が可能なことがあげられます(『第1回 XMLDBとCyber Luxeonの基本』の「XMLキャッシュ」参照)。分散キャッシュは、XMLキャッシュを複数のサーバーに分散して配置することによって、システム全体のパフォーマンス・可用性を向上することを目的とした機能です。ローカルセッションは、ローカルホストのDXE ObjectStoreサーバに直接接続しますので、Webアプリケーションのように並列にサーバーを配置してシステム全体のパフォーマンス向上を図るアプリケーション向けの用途ではありません。
DBトランザクション
Cyber LuxeonのDBトランザクションは、使用するセッションによって以下の表のような相違点があります。
セッション(接続先) | トランザクション | DOMオブジェクト更新のDBへの反映 |
クライアントセッション | センテンスごとのオートコミット | DBに反映されない |
ローカルセッション | プログラム内で明示的なトランザクション制御(開始・コミット・アボート)が可能。メソッド単位でのトランザクション定義も可能 | DBに直接反映される |
クライアントセッションのトランザクション
クライアントセッションのトランザクションは、XML更新センテンスごとのオートコミットになります。従って、クライアントセッションによる接続時のXML更新は、XUGを使用しての更新が有効な手段となります。XUGは、1つのXUG実行文内(xlnupdate要素内)で1トランザクションとなりますので、複数の更新文でトランザクションの整合性を保ちたい場合は、XUGの1つのXUG実行文内に複数の更新文を記述すれば要件を満たすことができます。
ローカルセッションのトランザクション
ローカルセッションのトランザクションは、プログラム内で明示的なトランザクション制御(開始・コミット・アボート)が可能です。またメソッド単位でのトランザクション定義も用意されています。またローカルセッションから取得したDOMオブジェクトを更新すると、Cyber Luxeon内のXMLデータに直接反映されます。
複数XMLドキュメントの検索
Cyber Luxeonでは「バインダドキュメント」という機能が用意されています。この機能を用いることによって複数のドキュメントをあたかも1つのXMLファイルであるかのように検索することができます。1つのバインダドキュメントとしてまとめられたXMLの仮想的なルート要素は「MultiDoc_Container」という名前の要素です。各XMLは、その子要素として結合されます。これにより、XMLを検索するプログラムは1つのXMLドキュメントに対しての検索として記述できるようになり、簡潔な検索文が記述できるようになります。本サンプルアプリケーションでは、この「バインダドキュメント」の機能を活用して、複数XMLドキュメントにまたがった商品名検索機能を実装します。
まとめ
本稿では、サンプルアプリーションの仕様・基本アーキテクチャについて主に説明しました。また、Cyber Luxeonのアプリケーション開発時に必要な知識である接続形態(セッション)の種類・特徴、DBトランザクション、バインダドキュメントの使用などについても説明しました。後編では、今回の説明を踏まえて、実装編としてCyber LuxeonのJava API、JAXBを用いた実際のソースコードの説明をしていきます。
参考資料
- 『Cyber Luxeon ハンドブック』 サイバーテック社
- TECHSCORE 『XMLサポートJava SE 6 Mustang』