Crystal Reports でCosmos DB データに連携して帳票を作成

詳細情報をご希望ですか?

無償トライアル:

ダウンロードへ

製品の詳細情報へ:

Cosmos DB JDBC Driver

Cosmos DB ドキュメントデータベース連携のパワフルなJava アプリケーションを素早く作成して配布。



レポートウィザードを使って、最新のCosmos DB 連携データを使った帳票を作成。



Crystal Reports には、JDBC 標準向けのサポートが組み込まれています。この記事では、Cosmos DB の機能を持つ帳票を作成するレポート作成ウィザードの使い方を説明します。

Cosmos DB JDBC Driver のインストール

CData JDBC Driver for Cosmos DB を、ドライバーのJAR をCrystal Reports のクラスパスに含めてインストール:DataDriverCommonElement の下のClassPath element のパスに、 .jar を含むファイルのフルパスを追加します。

CRConfig.xml は通常C:\Program Files (x86)\SAP BusinessObjects\SAP BusinessObjects Enterprise XI 4.0\java に配置されます。— パスはインストールによって若干異なる場合があります。ドライバーのJAR はインストールディレクトリの[lib]サブフォルダ内にあります。

ClassPath にJAR を追加したら、Crystal Reports を再起動します。

Cosmos DB データに接続

下記の手順に従って、レポート作成ウィザードを使ってCosmos DB 接続を作成します。

  1. 新しい空の帳票で、[Create New Connection]>[JDBC (JNDI)]をクリックします。
  2. ウィザードでJDBC 接続URL を選択します。

    jdbc:cosmosdb:AccountEndpoint=myAccountEndpoint;AccountKey=myAccountKey;
  3. ドライバーのクラス名を設定:

    cdata.jdbc.cosmosdb.CosmosDBDriver

    SQL API を使ってCosmos DB アカウントに接続するために必要な接続文字列を取得するには、Azure Portal にログインして「Azure Cosmos DB」を選択し、自分のアカウントを選択します。「Settings」セクションで、「Connection String」をクリックして次の値を設定します。

    • AccountEndpoint: 値は、Cosmos DB アカウントの「Keys」ブレードからのCosmos DB アカウントURL である必要があります。
    • AccountKey: Azure ポータルで、Cosmos DB サービスに移動してAzure Cosmos DB アカウントを選択します。リソースメニューから、 「Keys」ページに移動します。「PRIMARY KEY」値を見つけ、Token をこの値に設定します。

帳票をデザイン

JDBC 接続をCosmos DB に追加したら、レポート作成ウィザードを使ってCosmos DB を帳票に追加できます。

  1. 帳票に必要なテーブルやフィールドを選択して、データソースを設定します。この例では、Customers テーブルのCity およびCompanyName カラムを使います。

  2. チャートの種類を設定 ウィザードを完了すると、Crystal Reports はCosmos DB data に実行されるSQL クエリをビルドします。ドライバーは、ライブCosmos DB data に対してクエリを実行します。

  3. 必要に応じて、ほかのフィルタや帳票テンプレートを設定します。
  4. データのインポートが終わったら、データをサマライズもしくはソートするチャートやレポートオブジェクトを作成できます。[Insert]>[Chart]をクリックして、チャートエキスパートを開きます。Total CompanyName by City を表すグラフを作成するには、City を[On Change Of]メニューセレクションの下のボックスに追加してからCompanyName を[Show Values]の下のボックスに追加します。

完成した帳票をプレビューして、チャートにデータが入っていることを確認します。Null 値を取り除きたい場合は、SelectionFormula を使います。