はじめに
今回は、下記の2点について記載していこうと思います。
- 「Cloud SQL ※1」のMySQLにおけるインスタンス作成〜インポートによるテーブル作成
- 1.と「Tableau Desktop ※2」の接続方法
※1 Google CloudのMySQL、PostgreSQL、SQL Server 向けのフルマネージドリレーショナルデータベースサービス
※2 直感的なビジュアル分析が可能なBIツール
環境
MacBook Pro(M1チップ非搭載)
macOS Big Sur 11.7
phpmyadmin 4.9.3
Tableau Desktop 2022.4
目次
データ取得・dumpファイル生成
今回作成するテーブルのデータを取得します。既に使用したいデータが、手元にある場合はこのセクジョンについては最後のdumpファイル生成まで飛ばしてください。
データ取得
今回は下記のデータを使用して実装していきます。
- 対象ページにいき「Download」ボタンを押してzipファイルをダウンロードします。
- ダウンロードしたzipファイルをunzip等で回答してCSVデータを入手してください。
dumpファイル生成
Cloud SQLでデータをインポートする場合、下記の2パターンがあります。
①sqlファイルを読み込んでテーブルとデータをインポートする。
②事前にテーブルを作成しておき、csvでデータをインポートする。
今回は、テーブル作成とデータ格納が一気にできる①の方法で実装していきたいと考えているのでdumpファイル生成を行います。
dumpファイルの生成方法ですが、今回は手早く作成したいことと今後データが増えずに一定であることを加味してphpmyadminを利用してdumpファイルを生成します。phpmyadminにはGUI上でcsvをインポートしてテーブル作成を行い、それをエクスポートできる機能があるのでそちらの機能を使用して作成していきます。
-
csvファイルをインポートしてテーブルを作成します。csvファイルの形式によって必要なオプションを変更してください。今回のデータの場合は、1行目がカラム名になっているので「The first line of the file contains」のオプションにチェックを入れます。
-
出力されたSQLをコピーしてsqlファイルにコピーして保存してください。これをのちのセクションで使用します。
※デフォルトだとテーブル名が「TABLE」 「TABLE 1」等になっているので必要であれば「CREATE TABLE」の定義されているテーブル名を変更してください。
CloudSQLでのデータインポートによるテーブル作成
データインポートからCloudSQLでのテーブル作成を実施します。また既にGoogle Cloudのアカウントとプロジェクトは生成している想定で記載しています。また、無料トライアル期間が終わっている場合は課金が生じますのでご注意ください。
プロジェクトの作成方法は下記に記載があります。
インスタンス作成
- 「Cloud SQL」で検索してサービスのトップページを選択してください。
- 「インスタンスを作成」を押し、データベースエンジンは「MySQL」を選択してください。
- MySQLのインスタンスを作成します。条件によって内容を入力してください。今回は、仮実装なのでDevelopmentの構成で作成します。ゾーンの可用性もシングルゾーンにします。問題なければ「インスタンス作成」を選択してください。少し待つとインスタンスが生成されます。
データベース作成
Cloud StorageにSQLファイルをアップロード(事前準備)
インポート前にCloud Storageに前のセクションで作成したSQLファイルをアップロードしておく必要があります。
バケットの作成とアップロードについては下記のドキュメントをご参照ください。
データインポートによるテーブル作成
- 作成したインスタンスの「概要」タブのインポートを選択します。
- ソースはCloud Storageにアップロードしたファイルを選択してください。ファイル形式は「SQL」で接続先は「データベース作成」で作成したデータベース名にしてください。入力が終わったら「インポート」を選択します。処理が完了するとテーブルが作成されます。確認はCloud Shellを利用すると簡単にできます。
CloudSQLとTableauDesktopの接続
Tableau DesktopにはCloud SQLとのコネクタがサポートされているのでそれを使用していきます。
ドライバをインストール(ローカル)
事前に必要なドライバをローカルにインストールします。CloudSQLの場合は「iODBC ドライバーマネージャー」と「MySQL ODBC コネクタ」が必要になります。
- iODBC ドライバーマネージャをインストールします。mxkozzz.dmgを選択してダウンロードします。
2.MySQL ODBCコネクタをインストールします。OSに合うものをインストールしてください。
Cloud SQLのネットワーク設定
Cloud SQLへローカルPCから接続できるように設定を行います。
- 左タブメニューの「接続」を選択してください。
- 「ネットワーキング」の「承認済みネットワーク」下部にある「ネットワーク」の追加を選択します。
- 自身のグローバルネットワークアドレスを入力してください。確認くん等からご自身のIPアドレス(IPv4)を確認して入力を行い、「追加」を選択してください。
CloudSQLとTableauDesktopの接続
- Tableau Desktopを開いて「サーバーへ」→「その他」→「Cloud SQL」を選択してください。
- 下記の表示が出てくるので必要な情報を入力してください。
- サーバー欄: 「Cloud SQL」のパブリックIPアドレス
- ポート: MySQLなので「3306」
- データベース: 後から選択できるのでデフォルトもしくは対象のデータベース名を入れてください。
- ユーザー名: rootもしくは作成したユーザー
- パスワード: ユーザーのパスワード
3.接続したら可視化したいデータベース、テーブルを選択することで使用することができます。
最後に
今回は、Cloud SQLのインスタンス作成からTableau Desktop接続を一通り実装してみました。
Tableau Desktopにはコネクタがあるので比較的楽に実装ができました。
Bigqueryではなく、CloudSQLからBIツールを使用する機会もあると思うのでその際にお役に立てていただければ幸いです。
また認識違いがあればぜひご指摘をお願いします。