R から JDBC 経由でSAPののデータを分析

Jerod Johnson
Jerod Johnson
Senior Technology Evangelist
CData JDBC Driver for SAP を使って、お好みの開発環境と標準的な R 関数でSAP のデータを分析できます。

R と Java がインストールされている環境であれば、純粋な R スクリプトと標準的な SQL を使用してSAP のデータにアクセスできます。CData JDBC Driver for SAP と RJDBC パッケージを使えば、R からリモートのSAP のデータを操作できます。CData Driver を使用することで、業界で実績のある標準規格に準拠したドライバーを活用し、人気のオープンソース言語 R でデータにアクセスできます。この記事では、ドライバーを使ってSAPに SQL クエリを実行し、標準的な R 関数を呼び出してSAP のデータを可視化する方法を説明します。

SAP データ連携について

CData は、SAP のライブデータにアクセスし、統合するための最も簡単な方法を提供します。お客様は CData の接続機能を以下の目的で使用しています:

  • SAP R/3、SAP NetWeaver、SAP ERP / ECC 6.0、RFC によって公開されている SAP S/4 HANA オンプレミスデータを含む、すべてのエディションの SAP にアクセスできます。
  • SQL ストアドプロシージャを通じて、IDoc または IDoc XML ファイルのサーバーへの送信、関数やクエリ用のスキーマの作成などのアクションを実行できます。
  • お客様の SAP インスタンスがホストされている場所に応じて、最適に接続できます。
    • SAP S/4HANA クラウドパブリックエディションをご利用のお客様は、SAP NetWeaver Gateway 接続を使用します
    • SAP S/4HANA プライベートエディションをご利用のお客様は、SAP ERP または SAP NetWeaver Gateway 接続のいずれかを使用します。

多くのユーザーは、SAP データをデータベースやデータウェアハウスにレプリケートするために当社のツールを活用していますが、Tableau、Power BI、Excel などの分析ツールとライブ SAP データを統合しているお客様も多数います。


はじめに


R のインストール

マルチスレッドとマネージドコードによるドライバーのパフォーマンス向上を最大限に活かすには、マルチスレッド対応の Microsoft R Open を使用するか、BLAS/LAPACK ライブラリとリンクされたオープンソース R を使用します。この記事では Microsoft R Open 3.2.3 を使用しています。このバージョンは、2016年1月1日時点の CRAN リポジトリのスナップショットからパッケージをインストールするように事前設定されており、再現性が確保されています。

RJDBC パッケージの読み込み

ドライバーを使用するには、RJDBC パッケージをダウンロードしてください。 RJDBC パッケージをインストールしたら、以下のコードでパッケージを読み込みます。

library(RJDBC)

SAPに JDBC データソースとして接続

SAPに JDBC データソースとして接続するには、以下の情報が必要です。

  • Driver Class: cdata.jdbc.saperp.SAPERPDriver に設定します。
  • Classpath: ドライバー JAR ファイルの場所を設定します。デフォルトでは、インストールフォルダの lib サブフォルダです。

dbConnect や dbSendQuery などの DBI 関数は、R でデータアクセスコードを記述するための統一されたインターフェースを提供します。以下のコードで、CData JDBC Driver for SAP に JDBC リクエストを行う DBI ドライバーを初期化します。

driver <- JDBC(driverClass = "cdata.jdbc.saperp.SAPERPDriver", classPath = "MyInstallationDir\lib\cdata.jdbc.saperp.jar", identifier.quote = "'")

これで DBI 関数を使用してSAPに接続し、SQL クエリを実行できます。dbConnect 関数で JDBC 接続を初期化します。

CData 製品はSAP system にJCo JAR ファイルで接続します。Jco JAR ファイルの使い方は、ヘルプドキュメントの「はじめに」を参照してください。

また、SAP システムにSOAP Web service で接続することが可能です。SOAP アクセスには、Client、RFCUrl、User、Password の接続プロパティを入力します。

詳細情報はobtaining the connection properties を参照してください。

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

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

java -jar cdata.jdbc.saperp.jar

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

以下は、一般的な JDBC 接続文字列を含む dbConnect 呼び出しの例です。

conn <- dbConnect(driver,"jdbc:saperp:Host=sap.mydomain.com;User=EXT90033;Password=xxx;Client=800;System Number=09;ConnectionType=Classic;Location=C:/mysapschemafolder;")

スキーマの検出

このドライバーは、SAP API をリレーショナルテーブル、ビュー、ストアドプロシージャとしてモデル化します。以下のコードでテーブルの一覧を取得できます。

dbListTables(conn)

SQL クエリの実行

dbGetQuery 関数を使用して、SAP API でサポートされている任意の SQL クエリを実行できます。

mara <- dbGetQuery(conn,"SELECT MANDT, MBRSH FROM MARA")

以下のコマンドで、結果をデータビューアウィンドウに表示できます。

View(mara)

SAP のデータのプロット

これで、CRAN リポジトリで利用可能なデータ可視化パッケージを使ってSAP のデータを分析できます。組み込みのバープロット関数でシンプルな棒グラフを作成できます。

par(las=2,ps=10,mar=c(5,15,4,2))
barplot(mara$MBRSH, main="SAP MARA", names.arg = mara$MANDT, horiz=TRUE)

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

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

 ダウンロード

詳細:

SAP ERP Icon SAP ERP JDBC Driver お問い合わせ

極めて簡単にSAP NetWeaver と統合できます。データベースをクエリするのと同じくらい簡単に、任意のJDBC クライアントからSAP RFC にアクセスできるようになりました。