ノーコードでクラウド上のデータとの連携を実現。
詳細はこちら →CData
こんにちは!ウェブ担当の加藤です。マーケ関連のデータ分析や整備もやっています。
PostgreSQL には多くの対応クライアントがあります。標準のドライバーからBI、アナリティクスツールまで、PostgreSQL はデータ接続の人気のインターフェースです。JDBC ドライバーを使用することで、簡単に任意の標準クライアントから接続できるPostgreSQL エントリポイントを作成できます。
YouTube Analytics にPostgreSQL データベースとしてアクセスするには、CData JDBC Driver for YouTubeAnalytics とJDBC foreign data wrapper (FDW) を使用します。この記事ではFDW をコンパイルしてインストールし、PostgreSQL サーバーからYouTube Analytics にクエリを実行します。
JDBC データソースとしてYouTube Analytics に接続するには、以下が必要です。
Driver クラス
cdata.jdbc.youtubeanalytics.YouTubeAnalyticsDriver
YouTube Analytics への接続には、OAuth 認証標準を使います。ユーザーアカウントまたはサービスアカウントで認証できます。組織全体のアクセススコープをCData 製品に許可するには、サービスアカウントが必要です。下記で説明するとおり、CData 製品はこれらの認証フローをサポートします。
ユーザー資格情報の接続プロパティを設定せずに接続できます。次を設定して、接続してください。ChannelId:YouTube チャンネルのId に設定。指定しない場合、認証されたユーザーのチャンネルのデータが返されます。ContentOwnerId:コンテンツ所有者のレポートを生成する場合に設定。接続すると、CData 製品はデフォルトブラウザでOAuth エンドポイントを開きます。ログインして、アプリケーションにアクセス許可を与えます。CData 製品がOAuth プロセスを完了します。
他のOAuth 認証フローについては、ヘルプドキュメントの「OAuth 認証の使用」を参照してください。
JDBC URL の構成については、YouTube Analytics JDBC Driver に組み込まれている接続文字列デザイナを使用できます。JAR ファイルのダブルクリック、またはコマンドラインからJAR ファイルを実行します。
java -jar cdata.jdbc.youtubeanalytics.jar
接続プロパティを入力し、接続文字列をクリップボードにコピーします。
以下は一般的なJDBC URL です。
jdbc:youtubeanalytics:ContentOwnerId=MyContentOwnerId;ChannelId=MyChannelId;InitiateOAuth=GETANDREFRESH
FDW は、PostgreSQL を再コンパイルせずに、PostgreSQL の拡張機能としてインストールできます。例としてjdbc2_fdw 拡張子を使用します。
ln -s /usr/lib/jvm/java-6-openjdk/jre/lib/amd64/server/libjvm.so /usr/lib/libjvm.so
make install USE_PGXS=1
拡張機能をインストールした後、以下のステップに従ってYouTube Analytics へのクエリの実行を開始します。
CREATE EXTENSION jdbc2_fdw;
CREATE SERVER YouTubeAnalytics
FOREIGN DATA WRAPPER jdbc2_fdw OPTIONS (
drivername 'cdata.jdbc.youtubeanalytics.YouTubeAnalyticsDriver',
url 'jdbc:youtubeanalytics:ContentOwnerId=MyContentOwnerId;ChannelId=MyChannelId;InitiateOAuth=GETANDREFRESH',
querytimeout '15',
jarfile '/home/MyUser/CData/CData\ JDBC\ Driver\ for\ Salesforce MyDriverEdition/lib/cdata.jdbc.youtubeanalytics.jar');
CREATE USER MAPPING for postgres SERVER YouTubeAnalytics OPTIONS (
username 'admin',
password 'test');
postgres=# CREATE FOREIGN TABLE groups (
groups_id text,
groups_Snippet_Title text,
groups_ContentDetails_ItemCount numeric)
SERVER YouTubeAnalytics OPTIONS (
table_name 'groups');
postgres=# SELECT * FROM groups;
このようにCData JDBC Driver for YouTubeAnalytics を使って簡単にYouTube Analytics データを取得して検索対象にすることができました。ぜひ、30日の無償評価版 をお試しください。