R から JDBC 経由でMonday.comののデータを分析

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

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

R のインストール

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

RJDBC パッケージの読み込み

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

library(RJDBC)

Monday.comに JDBC データソースとして接続

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

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

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

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

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

Monday 接続プロパティの取得・設定方法

Monday AuditLog API

Monday AuditLog API は、API トークンによる認証のみをサポートしています。

監査ログAPI トークンを生成するには:

  1. monday.com アカウントにログインします。
  2. 画面右上のアバター(画像アイコン)をクリックします。
  3. 表示されたメニューからAdministration を選択します。
  4. 左側のナビゲーションでSecurity をクリックします。
  5. Audit タブをクリックします。
  6. Monitor by API -> Copy をクリックして、AuditLog API トークンをコピーします。

API トークンを取得した後、以下の接続プロパティを設定します。

  • Schema:"AuditLog" に設定。
  • AuthSchemeToken
  • APIToken:取得した監査ログAPI トークン
  • URL:Monday アカウントURL。ログイン後、自身のMonday ホームページのURL をコピーできます。例:https://your-account-name.monday.com/

Monday GraphQL API

Monday GraphQL API は、API トークンまたはOAuth 標準による認証をサポートしています。

API トークン

API トークンで接続するには、AuthSchemeToken に設定し、次の手順でAPIToken を取得します。

  1. monday.com アカウントにログインします。
  2. 画面右上のアバター(画像アイコン)をクリックします。
  3. 表示されたメニューからAdministration を選択します(管理者権限が必要です)。
  4. 左側のナビゲーションでConnections をクリックし、表示されたページでAPI タブをクリックします。
  5. Personal API Token で、Create token をクリックしてパーソナルAPI トークンを作成します。APIToken 接続プロパティをこの値に設定します。
    • すでにトークンを作成している場合は、Personal API TokenCopy ボタンをクリックしてAPI トークンをコピーします。APIToken 接続プロパティをこの値に設定します。

OAuth で認証する場合は、ヘルプドキュメントの「OAuth 認証の使用」セクションを参照してください。

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

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

java -jar cdata.jdbc.monday.jar

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

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

conn <- dbConnect(driver,"jdbc:monday:APIToken=eyJhbGciOiJIUzI1NiJ9.yJ0aWQiOjE0MTc4NzIxMiwidWlkIjoyNzI3ODM3OSwiaWFkIjoiMjAyMi0wMS0yMFQxMDo0NjoxMy45NDFaIiwicGV;")

スキーマの検出

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

dbListTables(conn)

SQL クエリの実行

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

invoices <- dbGetQuery(conn,"SELECT Id, DueDate FROM Invoices WHERE Status = 'SENT'")

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

View(invoices)

Monday.com のデータのプロット

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

par(las=2,ps=10,mar=c(5,15,4,2))
barplot(invoices$DueDate, main="Monday.com Invoices", names.arg = invoices$Id, horiz=TRUE)

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

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

 ダウンロード

詳細:

Monday.com Icon Monday.com JDBC Driver お問い合わせ

Monday.com データと連携するパワフルなJava アプリケーションを短時間・低コストで作成して配布できます。