各製品の資料を入手。
詳細はこちら →製品をチェック
JRuby からExact Online にデータ連携
リアルタイムExact Online に連携するシンプルなJRuby アプリケーションを作成します。
加藤龍彦デジタルマーケティング
最終更新日:2022-10-23
この記事で実現できるExact Online 連携のシナリオ
こんにちは!ウェブ担当の加藤です。マーケ関連のデータ分析や整備もやっています。
JRuby はRuby プログラミング言語の高性能で安定した、完全にスレッド化されたJava 実装です。CData JDBC Driver for ExactOnline を使用すると、JRuby からリアルタイムExact Online へのデータ連携を簡単に実装できます。ここでは、Exact Online に接続し、クエリを実行して結果を表示する簡単なJRuby アプリを作成する方法を説明します。
Exact Online のデータにJDBC で接続
アプリを作成する前に、JDBC Driver のJAR ファイルのインストール場所をメモします。 (通常はC:\Program Files\CDatat\CData JDBC Driver for ExactOnline\libにあります。)
JRuby は、JDBC をネイティブにサポートしているため、簡単にExact Online に接続してSQL クエリを実行できます。java.sql.DriverManager クラスのgetConnection 関数を使用してJDBC 接続を初期化します。
Exact Online はOAuth 認証標準を使用します。InitiateOAuth 接続プロパティはOAuth フローを容易にします。デフォルトではGETANDREFRESH です。埋め込みクレデンシャルを使用する、またはExact にOAuth アプリを登録して独自のクレデンシャルを取得することもできます。 OAuth 値に加え、Region を指定します。Division が設定されない場合は、デフォルトのDivision が使用されます。
詳しくは、ヘルプドキュメントの「はじめに」を参照してください。
ビルトイン接続文字列デザイナー
JDBC URL の構成については、Exact Online JDBC Driver に組み込まれている接続文字列デザイナーを使用してください。JAR ファイルのダブルクリック、またはコマンドラインからJAR ファイルを実行します。
java -jar cdata.jdbc.exactonline.jar
接続プロパティを入力し、接続文字列をクリップボードにコピーします。

以下はExact Online の一般的なJDBC 接続文字列です。
jdbc:exactonline:Region='United States';Division=5512;InitiateOAuth=GETANDREFRESH
Exact Online のデータへの接続性を持つJRuby アプリを作成
新しいRuby ファイル(例: ExactOnlineSelect.rb) を作成してテキストエディタで開き、次のコードをファイルにコピーします。
require 'java'
require 'rubygems'
require 'C:/Program Files/CData/CData JDBC Driver for ExactOnline 2018/lib/cdata.jdbc.exactonline.jar'
url = "jdbc:exactonline:Region='United States';Division=5512;InitiateOAuth=GETANDREFRESH"
conn = java.sql.DriverManager.getConnection(url)
stmt = conn.createStatement
rs = stmt.executeQuery("SELECT Name, CreditLinePurchase FROM Accounts")
while (rs.next) do
puts rs.getString(1) + ' ' + rs.getString(2)
end
ファイルが完成したら、コマンドラインからファイルを実行するだけでJRuby でExact Online を表示できるようになります。
jruby -S ExactOnlineSelect.rb
SQL-92 クエリをExact Online に書き込むと、Exact Online を独自のJRuby アプリケーションに素早く簡単に組み込むことができます。今すぐ無料トライアルをダウンロードしましょう。