Interstage Shunsaku Data Manager アプリケーション開発ガイド - Microsoft(R) Windows(R) 2000/ Microsoft(R) Windows Server(TM) 2003 - - UNIX共通 -
目次 索引 前ページ次ページ

付録F Java サンプルプログラム> F.1 データの検索

F.1.3 特定のXML文書をすべて取得する

検索操作において、“F.1.1 検索条件に一致するXML文書の件数を求める”および“F.1.2 検索条件に一致するXML文書を指定した形式で取得する”といった操作を経て、絞り込んだ条件を基に、データすべてを取得することになります。

F.1.2 検索条件に一致するXML文書を指定した形式で取得する”の操作により得られたホテル名を基に、該当するホテルのデータをすべて取得する例を用いて、Java APIの使用例を示します。

■検索条

「2006年7月18日に大阪で宿泊可能なホテルのうち、あるホテルの詳細情報を取得したい。」

年月日(2006年7月18日)および、場所(大阪)を条件に指定し、検索を実行します。また、ホテルに対応するレコードIDを用いて、詳細情報を取得します。

■APIの使用

以下にJava APIを使用したプログラミング例を示します。

import com.fujitsu.shun.ShunConnection;
import com.fujitsu.shun.ShunPreparedRecordID;
import com.fujitsu.shun.ShunPreparedStatement;
import com.fujitsu.shun.ShunResultSet;
import com.fujitsu.shun.common.ShunException;

/***     指定されたレコードIDに該当するレコード情報をすべて取得します     ***/
public class JavaAPISample3 {

  public static void main(String[] args) {
    ShunConnection con = null;
    ShunPreparedStatement pstmt = null;
    ShunPreparedRecordID rid = null;
    ShunResultSet rs = null;

    try {
      // 検索条件式
      String sQuery = "/document/base/prefecture == '大阪' AND /document/information/date == '2006年07月18日'";
      // リターン式
      String sReturn = "/document/base/name/text()";
      // レコード情報
      String sRecordID = "";
      // ヒット件数
      int iHitNum = 0;

      // ShunConnectionオブジェクトを作成
      con = new ShunConnection("DirSvr1", 33101);

      // 検索式を指定し、ShunPreparedStatementオブジェクトを作成
      pstmt = con.prepareSearch(sQuery, sReturn);

      //返信要求件数を設定
      pstmt.setRequest(1, 30);

      //検索を実行し、ShunResultSetオブジェクトを作成
      rs = pstmt.executeSearch();

      // ヒット件数取得
      iHitNum = rs.getHitCount();
      System.out.println("ヒット件数       = " + iHitNum);

      // ShunPreparedRecordIDオブジェクトを作成
      rid = con.prepareSearchRecordID();

      // 検索条件に該当するデータ1件を取得
      while (rs.next()) {
        // ホテル1の情報について、レコードIDを設定
        if (rs.getString().equals("ホテル1")) {
          rid.add(rs.getRecordID());
        }
      }
      rs.close();
      pstmt.close();

      // 該当レコードのID取得に成功している場合、詳細データを参照
      if (0 < rid.getCount()) {
        // 指定されたレコードIDでShunResultSetオブジェクトを作成
        rs = rid.searchByRecordID();
        while (rs.next()) {
          // レコードID指定でデータを取得
          System.out.println("[詳細] = " + rs.getString());
        }
        rs.close();
      }
      rid.close();
      con.close();
    }
    catch (ShunException ex) {
            int errorLevel = ex.getErrLevel();
      switch( errorLevel ) {
        case ShunException.SHUN_ERROR :
          System.out.println("エラーレベル  :SHUN_ERROR");
          break;
        case ShunException.SHUN_ERROR_CONNECTION_TERMINATED :
          System.out.println("エラーレベル  :SHUN_ERROR_CONNECTION_TERMINATED");
          break;
      }
      System.out.println("エラーメッセージ:" + ex.getMessage());
      ex.printStackTrace();
    }
    catch (Exception ex) {
      System.out.println("エラーメッセージ:" + ex.getMessage());
      ex.printStackTrace();
    }
    finally {
      try {
        if (rs != null)
          rs.close();
      }
      catch (ShunException ex) {
              int errorLevel = ex.getErrLevel();
      switch( errorLevel ) {
        case ShunException.SHUN_ERROR :
          System.out.println("エラーレベル  :SHUN_ERROR");
          break;
        case ShunException.SHUN_ERROR_CONNECTION_TERMINATED :
          System.out.println("エラーレベル  :SHUN_ERROR_CONNECTION_TERMINATED");
          break;
      }
        System.out.println("エラーメッセージ:" + ex.getMessage());
        ex.printStackTrace();
      }
      try {
        if (pstmt != null)
          pstmt.close();
      }
      catch (ShunException ex) {
              int errorLevel = ex.getErrLevel();
      switch( errorLevel ) {
        case ShunException.SHUN_ERROR :
          System.out.println("エラーレベル  :SHUN_ERROR");
          break;
        case ShunException.SHUN_ERROR_CONNECTION_TERMINATED :
          System.out.println("エラーレベル  :SHUN_ERROR_CONNECTION_TERMINATED");
          break;
      }
        System.out.println("エラーメッセージ:" + ex.getMessage());
        ex.printStackTrace();
      }
      try {
        if (rid != null)
          rid.close();
      }
      catch (ShunException ex) {
              int errorLevel = ex.getErrLevel();
      switch( errorLevel ) {
        case ShunException.SHUN_ERROR :
          System.out.println("エラーレベル  :SHUN_ERROR");
          break;
        case ShunException.SHUN_ERROR_CONNECTION_TERMINATED :
          System.out.println("エラーレベル  :SHUN_ERROR_CONNECTION_TERMINATED");
          break;
      }
        System.out.println("エラーメッセージ:" + ex.getMessage());
        ex.printStackTrace();
      }
      try {
        if (con != null)
          con.close();
      }
      catch (ShunException ex) {
              int errorLevel = ex.getErrLevel();
      switch( errorLevel ) {
        case ShunException.SHUN_ERROR :
          System.out.println("エラーレベル  :SHUN_ERROR");
          break;
        case ShunException.SHUN_ERROR_CONNECTION_TERMINATED :
          System.out.println("エラーレベル  :SHUN_ERROR_CONNECTION_TERMINATED");
          break;
      }
        System.out.println("エラーメッセージ:" + ex.getMessage());
        ex.printStackTrace();
      }
    }
  }
}

■実行結

ヒット件数       = 3
[詳細] = <document>
    <base>
        <name>ホテル1</name>
        <prefecture>大阪</prefecture>
        <address>大阪府大阪市中央区</address>
        <detail>http://xxxxx.co.jp</detail>
        <price>9000</price>
    </base>
    <information>
        <date>2006年07月18日</date>
    </information>
    <note>バス付 トイレ付 地下鉄 △△駅徒歩02分</note>
</document>

目次 索引 前ページ次ページ

All Rights Reserved, Copyright(C) 富士通株式会社 2006