ページの先頭行へ戻る
Interstage Shunsaku Data Manager V9.0.6 アプリケーション開発ガイド
FUJITSU Software

F.1.2 検索条件に一致するXML文書を指定した形式で取得する

検索操作において、検索結果として得られたデータの一部を追加条件として次の検索を行うことがよくあります。このような場合、検索結果としてはデータのすべてではなく、その一部を取得することが一般的です。


日付と場所を検索条件式に指定して、条件に一致するホテルの件数と部分情報を取得する例を用いて、Java APIの使用例を示します。


検索条件

「2006年7月18日に大阪で宿泊可能なホテルのホテル名と宿泊費を最大30件分知りたい。」

年月日(2006年7月18日)および、場所(大阪)を条件に指定します。また、取得する結果はホテル名と宿泊費を指定し、検索を実行します。


APIの使用例


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

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

/***     指定された検索条件に該当するレコード件数と、データを取得します     ***/
public class JavaAPISample2 {

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

    try {
      // 検索条件式
      String sQuery = "/document/base/prefecture == '大阪' AND /document/information/date == '2006年07月18日'";
      // リターン式
      String sReturn = "/document/base/name, /document/base/price";
      // ヒット件数
      int iHitNum = 0;
      // データ件数のカウンタ
      int iDataCounter = 1;

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

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

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

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

      // ヒット件数取得
      iHitNum = rs.getHitCount();
      System.out.println("ヒット件数       = " + iHitNum);
      // 検索条件に該当するデータを、1件ずつ取得
      while (rs.next()) {
        System.out.println("[結果]" + iDataCounter + "件目 = " + rs.getString());
        iDataCounter++;
      }
      rs.close();
      pstmt.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 (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
[結果]1件目 = <document><name>ホテル1</name><price>9000</price></document>
[結果]2件目 = <document><name>ホテル2</name><price>6000</price></document>
[結果]3件目 = <document><name>ホテル3</name><price>7500</price></document>