| Interstage Application Server アプリケーション作成ガイド (データベース連携サービス編) | 
			目次
			索引
			![]()  
		 | 
	
| 第3章 クライアントアプリケーションの作成 | > 3.4 クライアントアプリケーションソースの作成(CurrentインタフェースのJava言語) | > 3.4.2 ソースの作成 | 
グローバルトランザクション運用を行うためには、CORBAのクライアントアプリケーションの処理に加えて、CosTransactions.Current.commitメソッドなどのCurrentインタフェースを呼び出して、データベース連携サービスにトランザクション処理を依頼します。
これらの処理を考慮したクライアントアプリケーションの構成について以下に示します。

クライアントアプリケーションをCORBAサービスに登録、およびトランザクションサービスの初期化を行います。
アプリケーション固有の処理部。トランザクションの開始から終了までの流れを記述します。
データベース連携サービスが提供するクライアントアプリケーション用ライブラリを結合します。
クライアントアプリケーションの基本形を以下に示します。
try{
    /* 初期化処理  */
                :
    orb = org.omg.CORBA.ORB.init(args, null);
                :
    /* ネーミングサービスのオブジェクトリファレンスの獲得 */
                :
    org.omg.CORBA.Object _tmpObj2 =
                   Orb.resolve_initial_references("NameService");
    Cos  =  org.omg.NamingContextExtHelper.narrow(_tmpObj2);                … 1
                :
    /* トランザクション依頼処理  */
    org.omg.CORBA.Object  _tmpObj1 =
                   Orb.resolve_initial_references("TransactionCurrent");
    Current  = org.omg.CosTransactions.CurrentHelper.narrow(_tmpObj1);   … 2
                :
    /*サーバアプリケーションのオブジェクトリファレンス獲得 */
    String NCid = new String("bankA::accountA");
    String NCkind = new String("");
    
    try {
        NameComponent nc = new NameComponent( NCid, NCkind );
        NameComponent NCo[] = { nc };
        Obj = Cos.resolve( NCo );
        target = accountAHelper.narrow( Obj );
    }
    Current.begin();                                                   … 3
                :
    obj->ope1(para);                                                   … 4
    Current.commit(rhuristic);                                         … 5
}
catch(CORBA.CORBAException e){
    Current.rollback();                                                … 6
} | 
			目次
			索引
			![]()  
		 |