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

I.1.5 検索条件に一致するXML文書の値を集計して取得する

検索操作において、検索した結果をある特定の要素の値を集計して取得したい場合があります。


場所を検索条件式に指定して、最も安い宿泊費、最も高い宿泊費、宿泊費の平均値を取得する例を用いて、C++ .NETの使用例を示します。


検索条件

「2006年7月18日に宿泊可能なホテルのうち、最も安い宿泊費、最も高い宿泊費、宿泊費の平均値を地域別に集計して欲しい。」

年月日(2006年7月18日)を条件に指定します。また、取得する結果に集計式(min, max, avg)を指定し、集計結果を取得します。


APIの使用例


以下にC++ .NETを使用したプログラミング例を示します。

#using <mscorlib.dll>
#using <system.dll>
#using <Fujitsu.Shunsaku.dll>

using namespace System;
using namespace Fujitsu::Shunsaku;

class SampleSort2 {
public:
  static void Main( String *args __gc[] ) {
    ShunService *service = 0;

    try {
      // ShunService の作成
      service = new ShunService();

      // ホスト名 ポート番号を指定して Shunsaku に接続
      service->Host = "DirSvr1";
      service->Port = 23101;
      service->Connect();

      // ShunSearchRequirement の作成
      ShunSearchRequirement *req = new ShunSearchRequirement();
      
      // 各種検索条件の設定
      req->QueryExpression = "/document/information/date == '2006年07月18日'";
      req->ReturnExpression = "/document/base/prefecture/text(), min(/document/base/price/text()), max(/document/base/price/text()), avg(/document/base/price/text())";
      req->SortExpression = "/document/base/prefecture/text()";
      req->ReplyNumber = 1;
      req->RequestCount = 30;
      
      // 検索条件を指定して検索を実行
      ShunResultSet *rs = service->Search( req );

      // 検索結果の表示
      // 検索条件に該当するデータを取得
      int i = 0;
      ShunRecordEnumerator *enumerator = rs->Records->GetEnumerator();
      while ( enumerator->MoveNext() ) {
        ShunRecord *record = enumerator->Current;
        ++i;
        Console::WriteLine( "[結果]{0}件目:", __box( i ) );
        String *result __gc[,] = record->GetDividedDataAsTwoRankArray();
        Console::WriteLine("  地域          :{0}", result[0,0]);
        Console::WriteLine("  最も安い宿泊費:{0}", result[1,0]);
        Console::WriteLine("  最も高い宿泊費:{0}", result[2,0]);
        Console::WriteLine("  宿泊費の平均値:{0}", result[3,0]);
      }

      // Shunsaku から切断
      service->Disconnect();

    }
    catch ( ShunContinuousException *e ) {
      // ShunContinuousExceptionが発生した場合の処理を記述
      try {
        if( service != 0 && service->State == ShunConnectionState::Open ) {
          service->Disconnect();
        }
      }
      catch ( ShunException *ex ) {
        Console::WriteLine( "エラーメッセージ : {0}", ex->Message );
      }
      Console::WriteLine( "エラーメッセージ : {0}", e->Message );
    }
    catch ( ShunConnectionTerminatedException *e ) {
      // ShunConnectionTerminatedExceptionが発生した場合の処理を記述
      Console::WriteLine( "エラーメッセージ : {0}", e->Message );
    }
  }
};
int main() {
  return SampleSort2::Main( Environment::GetCommandLineArgs() );
}

実行結果

[結果]1件目:
  地域          :神奈川
  最も安い宿泊費:6000
  最も高い宿泊費:8000
  宿泊費の平均値:7000
[結果]2件目:
  地域          :大阪
  最も安い宿泊費:6000
  最も高い宿泊費:9000
  宿泊費の平均値:7500