Node.js で Google Calendar のデータを MySQL データベースとしてクエリ

Jerod Johnson
Jerod Johnson
Senior Technology Evangelist
Node.js からGoogle Calendar のデータに対して MySQL クエリを実行する方法を紹介します。

Google Calendar 用の ODBC Driver の SQL Gateway を使用すると、MySQL インターフェース経由でGoogle Calendar のデータをクエリできます。以下の手順に従って、SQL Gateway の MySQL リモーティングサービスを起動し、Node.js からクエリを開始してください。

Google Calendar のデータに接続

まだ行っていない場合は、データソース名(DSN)で必要な接続プロパティの値を指定してください。組み込みの Microsoft ODBC データソースアドミニストレーターを使用して DSN を設定できます。これはドライバーインストールの最後のステップでもあります。Microsoft ODBC データソースアドミニストレーターを使用して DSN を作成・設定する方法については、ヘルプドキュメントの「はじめに」の章を参照してください。

Google Calendar はOAuth 認証標準を利用しています。各ユーザー やドメイン内のユーザーの代わりに、CData 製品がGoogle API にアクセスすることを許可できます。 接続すると、CData 製品はデフォルトブラウザでOAuth エンドポイントを開きます。ログインして、アプリケーションにアクセス許可を与えます。CData 製品がOAuth プロセスを完了します。

詳細はヘルプドキュメントを参照してください。

SQL Gateway を設定

SQL Gateway 概要を参照して、Google Calendar のデータ を仮想 MySQL データベースとして接続を設定してください。クライアントからの MySQL リクエストをリッスンする MySQL リモーティングサービスを設定します。サービスは SQL Gateway UI で設定できます。

SQL Gateway で MySQL リモーティングサービスを作成(Salesforce の例)

Node.js から Google Calendar をクエリ

以下の例では、mysql モジュールを使用して Google Calendar への接続を定義し、クエリを実行する方法を示しています。以下の情報が必要です。

  • ホスト名またはアドレス、およびポート:MySQL リモーティングサービスが MySQL 接続をリッスンしているマシンとポート
  • ユーザー名パスワード:SQL Gateway の Users タブで認証したユーザーのユーザー名とパスワード
  • データベース名:MySQL リモーティングサービス用に設定した DSN

以下のコードでGoogle Calendar のデータに接続し、クエリの実行を開始できます。

var mysql      = require('mysql');
var connection = mysql.createConnection({
  host     : 'localhost',
  database : 'CData GoogleCalendar Sys',
  port	   : '3306',
  user     : 'mysql_user',
  password : 'test'
});
connection.connect();
connection.query('SELECT * FROM VacationCalendar', function(err, rows, fields) {
  if (err) throw err;
  console.log(rows);
});

connection.end();

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

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

 ダウンロード

詳細:

Google Calendars Icon Google Calendars ODBC Driver お問い合わせ

Google Calendar ODBC Driver は、ODBC 接続をサポートするさまざまなアプリケーションからGoogle カレンダーのリアルタイムデータ連携を実現するパワフルなツールです.

データベースにアクセスするときと同感覚でGoogle カレンダーデータにアクセスし、標準ODBC Driver インターフェースを通じてCalendars、Events、Attendees、etc. にアクセス。