はじめに
HiRDB Version 10 10-09
2025年1月リリースのHiRDB Version 10 10-09から正式にTableauに対応しました。
これまでの検証をもとに、Dialectなどを新規に作成し、テストにより品質を確保した製品版のコネクターをHiRDBに同梱しています。本記事の後半では製品版のコネクターの使用方法などを解説しています。
本題
前回、コネクターの主要な構成ファイルであるDialectとManifest file(capabilityを記述するファイル)を作成しました。
コネクターの完成には残りの構成ファイルの作成と構成ファイルのTACOファイルへのパッケージ化が必要になります。
第1回でご説明した通り、コネクターの作成には以下の手順が必要です。
手順1:Tableau Connector SDKをインストールする
手順2:設定用ファイルを作成する
手順3:テストツールによりTableauとDBの接続~クエリなどの処理が実行できることを確認する
手順4:作成したファイルをパッケージ(TACOファイル)にまとめる
第2回までで、手順2のManifest file(capability)とDailectファイルの作成まで行いました。
今回は以下を行いコネクターを完成させていきます。
・接続時の画面のカスタマイズに関するファイルなど残りの構成ファイルの作成(上記の手順2)
・作成したファイルのパッケージ化(上記の手順4)
コネクターの完成後、HiRDBに接続し正しく動作するか確認します。
残りの構成ファイルを作成する
残りのファイルはいくつかありますが、特に重要で接続時画面のカスタマイズに関わる「connectionFields」と接続時画面で入力された値に基づき、DB接続用のJDBCのURLを作成する「connectionBuilder」について作成・確認していきます。
コネクターの主要な構成ファイル
ファイル | 役割 |
---|---|
Manifest file ✓ | コネクターの名前や、コネクター・DBの仕様についてTableauに連携する |
Tableau Dialect file ✓ | Tableau側からDBのデータを取得する際のSQLの記述を定義 |
Connector Resolver file | 設定用スクリプトの呼び出しなどを行う |
connectionFields ※ | コネクションダイアログで受け取る入力情報について設定 |
connectionBuilder ※ | JDBC利用時のURL作成 |
※今回の説明対象
✓第2回で作成
「Connector Resolver file」などについては、PostgreSQL用のものでHiRDBの接続に必要な最低限の情報は揃うので代用可能です。今回はお試し版ということでPostgreSQL用のコネクターのものを代用して検証を進めていきます。
実際の内容は下記URLを参照してください。
接続に関するカスタマイズ
TableauからDBに接続する際、以下のような画面が表示されユーザー名など接続に必要な情報を入力します。
コネクターの構成ファイルであるconnectionFieldsなどを編集することで、追加の入力情報を受け付けられるようにするなど、カスタマイズすることが可能です。
こちらもお試し版としてはPostgreSQL用のもので代用可能なため、PostgreSQL用のconnectionFieldsで検証を進めていきます。
今回使用したPostgreSQL用コネクターのconnectionFieldsは以下になります。
接続時のJDBCに関するファイル
第1回でご説明したように、TableauからDBへの接続はTableau側の処理をコネクターによりSQLへ変換し、DBに対し実行することで行われます。
コネクターの変換により得られたSQLはJDBCを介してDBに渡されます。
そのため、JDBC利用時のURLの組み立てに関する設定用ファイルも作成する必要があります。
JDBC利用時のURLの組み立てはコネクターの構成ファイルである、connectionBuilderで行われます。
connectionBuilderはTableauからDBに接続する際に入力された情報をもとに、JDBC利用時のURLを組み立てます。接続時に入力された、接続先のホスト名とポート番号をもとにURLを組み立てる場合は以下のようになります。
(function dsbuilder(attr) {
var urlBuilder = "jdbc:hitachi:hirdb://DBID=" + attr[connectionHelper.attributePort]
+ ",DBHOST=" + attr[connectionHelper.attributeServer];
return [urlBuilder];
})
接続時に入力されたポート番号、接続先ホスト情報をそれぞれHiRDBにおけるJDBC利用時のURLの要素であるDBID、DBHOSTの指定値として代入されるように文字列を結合させています。
先程の接続時の画面との関係は下の通りで、Serverの項目に入力したものがJDBC接続時URLのDBHOSTに、Portに入力したものがDBIDにそれぞれ設定されます。
Usernameなどに入力した値についてはJDBC接続時のURLには直接使用されず、内部的に接続時の処理などに使用されます。
その他、カスタマイズできる要素もありますが、お試し版コネクターとしてはひとまず構成ファイルの作成は完了です。
コネクターのパッケージ化
ここまで作成してきたファイルを専用のツールによりパッケージ化していきます。
詳細な手順は公式ページをご参照ください。
手順1.環境の構築
Tableau Connector SDKやPythonなど必要なソフトをインストールします。
インストールしたTableau Connector SDKの配下にあるconnector-packager内に、venvコマンドで仮想環境を作成します。
> python -m venv .venv
作成した仮想環境を有効化します。
> .¥.venv¥Scripts¥activate
pipコマンドで必要なパッケージをインストールします。
> pip install -e .
手順2.パッケージ化
コネクターの構成ファイルがそろっていることを確認し、次のコマンドを実行することでパッケージ化されたコネクターが作成されます。
> python -m connector_packager.package [コネクターの構成ファイルの格納フォルダのパス]
完成
パッケージ化されたコネクターは、connector-packager下のpackaged-connectorフォルダに作成されます。
「.taco」の形式で作成されていることが確認できました。
これでコネクターが完成しました。続いて、実際にコネクターを使ってみます。
接続してみる
製品版
冒頭で記載の通り、本記事の作成中に製品版としてのコネクターが完成しリリースされましたので、製品版のコネクターを使って接続していきます。
環境
なお、今回の環境は以下の通りです。クライアントとサーバーについては同一マシン上に構築しています。
・HiRDB Server Version 10 10-09
・Tableau 2024.1.0
※TableauやHiRDBのバージョンにより手順が異なる場合があります。
手順1.コネクターの格納
HiRDBに同梱のコネクターを以下の場所に格納します。
「C:¥Users¥[Windows ユーザー]¥Documents¥My Tableau Repository¥Connectors」
手順2.JDBCドライバの格納
続いて、同じくHiRDBに同梱されているType4 JDBCドライバを以下のフォルダに格納します。
「C:¥Program Files¥Tableau¥Drivers」
手順3.サインイン
Tableauを起動します。
Tableau起動後の画面左側に接続先を選択するバーが表示されます。バーの「サーバーへ」の「その他…」を選択すると利用可能なコネクターの一覧が表示されます。
その中から、使用したいコネクター(今回は「HITACHIによるHiRDB JDBC」)を選択します。
接続に必要な情報を入力する画面が表示されます。
以下を入力し「サインイン」を押下することでHiRDBに接続することができます。
項目 | 指定内容 |
---|---|
Server | 接続先HiRDBのIPアドレス、PDHOSTに相当するもの |
Port | 接続先HiRDBのポート番号、PDNAMEPORTに相当するもの |
データベース | Tableauの画面上に表示したいデータベース名称 |
Username | HiRDB接続時のユーザー名、PDUSERに相当するもの |
Password | 上記ユーザーのパスワード |
HiRDB.iniの格納ディレクトリ | HiRDB.iniによるクライアント環境変数を定義したい場合、HiRDB.iniの格納ディレクトリを指定 |
接続先HiRDBサーバの文字コード | 接続先HiRDBサーバの文字コードについて入力する場合に指定 |
接続に成功すると、接続先DBについての情報やテーブルの一覧が表示されます。
接続に成功し、テスト用に作成したテーブルなどが表示されていることを確認できました。
分析したいテーブルを画面中央部にドラッグ&ドロップすることで、データの可視化や分析など様々な操作を始めることができます。
次回
実際にTableauを操作し、HiRDBに格納されているデータの可視化や分析を行ってみます。
商標など
Tableauは、Salesforce, Inc.の商標です。
PostgreSQLは、PostgreSQL Community Association of Canadaのカナダにおける登録商標およびその他の国における商標です。
"Python" is a registered trademark of the Python Software Foundation.
その他記載の会社名、製品名は、それぞれの会社の商標もしくは登録商標です。
製品の改良により予告なく記載されている仕様が変更になることがあります。
参考