本記事では CData サポート担当からこんなことを聞かれたらどこを確認すべきか?という観点で、よく頂くお問合せ内容をご紹介します。
記事はこちら →Pure R スクリプトおよび 標準SQL を使って、R およびJava をインストール可能なあらゆるマシン上でSAP HANA XS Advanced にアクセス。CData JDBC Driver for SAPHanaXSA とRJDBC package を使って、R でリモートSAP HANA XS Advanced data を利用できます。CData Driver を使うことで、業界が認めた基準で書かれたドライバーを活用して、オープンソースでポピュラーなR 言語のデータにアクセスできます。この記事では、ドライバーを使ってSAP HANA XS Advanced にSQL クエリを実行する方法、および標準R 関数を呼び出してSAP HANA XS Advanced をビジュアライズする方法について説明します。
マルチスレッドのMicrosoft R Open を実行すること、またはBLAS/LAPACK ライブラリにリンクされたオープン R を実行することによって、マルチスレッドおよびマネージドコードから利益を得られたドライバーのパフォーマンスにマッチできます。ここでは、Microsoft R Open 3.2.3 を使用します。CRAN レポジトリのJan. 1, 2016 snapshot からパッケージをインストールするために事前設定されています。このsnapshot は再現性を保証します。
ドライバーを使うにはRJDBC パッケージをダウンロードします。RJDBC パッケージをインストールしたら、次のコードを入力してパッケージをロードします。
library(RJDBC)
下記の情報を使いSAP HANA XS Advanced にJDBC データソースとして接続します。
dbConnect やdbSendQuery のようなDBI 関数は、R にデータアクセスコードを書くための統一インターフェースを提供します。
driver <- JDBC(driverClass = "cdata.jdbc.saphanaxsa.SAPHanaXSADriver", classPath = "MyInstallationDir\lib\cdata.jdbc.saphanaxsa.jar", identifier.quote = "'")
これで、DBI 関数を使ってSAP HANA XS Advanced に接続しSQL クエリを実行する準備が整いました。dbConnect 関数を使ってJDBC 接続を初期化します。一般的なJDBC 接続文字列は次のとおりです。
conn <- dbConnect(driver,"OAuthClientID=my-ouath-client-id;OAuthClientSecret=my-oauth-client-secret;URL=https://hxehost:51027/euro.xsodata;CallbackURL=http://localhost:33333;")
SAP HANA XSA uses the OAuth authentication standard. Before connecting, it is necessary to establish an SAP HANA XSA OData Service. See the OAuth section in the Help documentation for a guide.
ドライバーはSAP HANA XS Advanced API をリレーショナルデータベース、ビュー、ストアドプロシージャとしてモデルします。次のコードを使ってテーブルリストを検出します。
dbListTables(conn)
dbGetQuery 関数を使ってSAP HANA XS Advanced API がサポートするすべてのSQL クエリを実行できます:
<- dbGetQuery(conn,"SELECT , FROM WHERE = ''")
次のコマンドを使って、結果を[data viewer]ウィンドウで見ることができます。
View()
CRAN レポジトリで利用可能なあらゆるデータ初期化パッケージを使ってSAP HANA XS Advanced を分析する準備が整いました。ビルトインバーのplot 関数を使って簡単なバーを作成できます。
par(las=2,ps=10,mar=c(5,15,4,2)) barplot($, main="SAP HANA XS Advanced ", names.arg = $, horiz=TRUE)