ColdFusion から SAP Business Warehouse のデータにクエリ

Jerod Johnson
Jerod Johnson
Director, Technology Evangelism
ColdFusion の標準データアクセスコードで SAP Business Warehouse のデータ に接続。



CData JDBC ドライバーを使用すると、ColdFusion の高速開発ツールを使って SAP Business Warehouse のデータ にシームレスに接続できます。本記事では、ColdFusion から SAP Business Warehouse のデータ に接続し、SAP Business Warehouse テーブルにクエリを実行する方法を説明します。

ColdFusion で SAP Business Warehouse 用JDBC データソースを作成

JDBC データソースを設定すると、cfquery タグや executeQuery などのCFScript から標準SQL を実行できるようになります。

  1. インストールディレクトリから、ドライバーのJAR ファイルと.lic ファイルをColdFusion のクラスパスにコピーします。例えば、C:\MyColdFusionDirectory\cfusion\wwwroot\WEB-INF\lib にコピーします。または、ColdFusion Administrator の[Java と JVM]ページで、[ColdFusion Class Path]ボックスにファイルへのパスを入力します。

    ドライバーのJAR ファイルとライセンスファイルは、インストールディレクトリの lib サブフォルダにあります。

    この手順の後、サーバーを再起動してください。

  2. ドライバーをデータソースとして追加します。

    ColdFusion Administrator 画面で、[データ&サービス]ノードを展開し、[データソース]をクリックします。[新しいデータソースの追加]セクションで、データソースの名前を入力し、[ドライバー]メニューから[Other]を選択します。

  3. ドライバーのプロパティを設定します。

    • JDBC URL:JDBC URL に接続プロパティを入力します。JDBC URL は jdbc:sapbusinesswarehouse: で始まり、その後にセミコロン区切りで name=value 形式の接続プロパティを指定します。

      SAP Business Warehouse に接続するには、URL プロパティを有効なSAP Business Warehouse サーバーのベースURL に設定します。ドライバーはXMLAアクセスを使用してHTTP 上でホストされたSAP Business Warehouse インスタンスに接続する必要があります。

      ドライバーはAuthScheme プロパティを通じて以下の認証スキームをサポートしています:

      • None:サーバーで使用可能な場合、匿名認証。
      • BasicUserPassword を設定し、AuthSchemeBasic に設定します。
      • Kerberos:必要なKerberos プロパティについては、ヘルプドキュメントの「Kerberos の使用」セクションを参照してください。

      デフォルトでは、ドライバーはシステムの信頼された証明書ストアに対してサーバーの証明書を確認することでSSL/TLS のネゴシエーションを試みます。別の証明書を指定するには、使用可能な形式についてSSLServerCert プロパティを参照してください。

      組み込みの接続文字列デザイナー

      JDBC URL の構築には、SAP Business Warehouse JDBC ドライバーに組み込まれた接続文字列デザイナーをご利用ください。JAR ファイルをダブルクリックするか、コマンドラインから実行します。

      java -jar cdata.jdbc.sapbusinesswarehouse.jar
      

      接続プロパティを入力し、接続文字列をクリップボードにコピーします。

      一般的なJDBC URL は次のようになります。

      jdbc:sapbusinesswarehouse:URL=https://mysapserver:8000;AuthScheme=Basic;User=username;Password=password;
    • Driver Class:ドライバークラスを入力します。ドライバークラスは cdata.jdbc.sapbusinesswarehouse.SAPBusinessWarehouseDriver です。
    • Driver Name:ドライバーのユーザー定義名を入力します。
    • Username:認証に使用するユーザー名を入力します。
    • Password:認証に使用するパスワードを入力します。

これで、[操作]列で CData SAP Business Warehouse データソースを有効にして接続をテストできます。ステータスがOK と表示されたら、SAP Business Warehouse データソースの準備完了です。

クエリの実行

cfquery タグで SAP Business Warehouse にSQL ステートメントを送信できます。cfqueryparam タグを使用して、パラメータ化クエリを作成し、クエリ文字列によるSQL インジェクションを防止します。

注意cfquerycfscript を使用するには、.cfm ファイルを作成します。その.cfm ファイル内に、クエリを実行するコードを記述します(下記参照)。ファイルをWeb サーバーのルートディレクトリ(Adobe ColdFusion の場合はwwwroot など)に直接配置します。変更を反映するには、ファイル配置後にサービスを再起動してください。


<cfquery name="SAPBusinessWarehouseQuery" dataSource="CDataSAPBusinessWarehouse">
  SELECT * FROM Sales WHERE Country = <cfqueryparam value="#Country#" cfsqltype="cf_sql_varchar">
</cfquery>
<cfdump var="#SAPBusinessWarehouseQuery#">

CFScript で記述すると以下のようになります。


<cfscript>
result = queryExecute(
  "SELECT * FROM Sales WHERE Country = ?",
  [
    { value="US", cfsqltype="cf_sql_varchar" }
  ],
  { datasource="CDataSAPBusinessWarehouse" }
);

writeDump( var= result );
</cfscript>

その後、以下のように.cfm ファイルにリクエストを送信できます。

http://MyServer:8500/query.cfm?Country=US

はじめる準備はできましたか?

SAP Business Warehouse Driver の無料トライアルをダウンロードしてお試しください:

 ダウンロード

詳細:

SAP Business Warehouse Icon SAP Business Warehouse JDBC Driver

SAP Business Warehouse と連携する高機能なJava アプリケーションを迅速に開発・デプロイ。