Node.js で Adobe Experience Manager のデータを MySQL データベースとしてクエリ
Adobe Experience Manager 用の ODBC Driver の SQL Gateway を使用すると、MySQL インターフェース経由でAdobe Experience Manager のデータをクエリできます。以下の手順に従って、SQL Gateway の MySQL リモーティングサービスを起動し、Node.js からクエリを開始してください。
Adobe Experience Manager のデータに接続
まだ行っていない場合は、データソース名(DSN)で必要な接続プロパティの値を指定してください。組み込みの Microsoft ODBC データソースアドミニストレーターを使用して DSN を設定できます。これはドライバーインストールの最後のステップでもあります。Microsoft ODBC データソースアドミニストレーターを使用して DSN を作成・設定する方法については、ヘルプドキュメントの「はじめに」の章を参照してください。
Adobe Experience Manager(AEM)の WebDAV 経由で JCR リポジトリを公開するインスタンスに接続します。オンプレミスの AEM と AEM as a Cloud Service の両方のデプロイメントに対応しています。
接続するには、以下のプロパティを設定してください。
- URL: WebDAV 対応の JCR サーバー URL。
- AEM as a Cloud Service: https://author-pXXXXX-eXXXXX.adobeaemcloud.com/crx/server
- ローカル開発: http://localhost:4502/crx/server
- User: AEM のユーザー名。
- Password: AEM のパスワード。
注意: テーブルは JCR リポジトリの構造に基づいて動的に生成されます。設定したユーザーが AEM リポジトリ内の必要なコンテンツパスにアクセスするための十分な権限を持っていることを確認してください。
SQL Gateway を設定
SQL Gateway 概要を参照して、Adobe Experience Manager のデータ を仮想 MySQL データベースとして接続を設定してください。クライアントからの MySQL リクエストをリッスンする MySQL リモーティングサービスを設定します。サービスは SQL Gateway UI で設定できます。

Node.js から Adobe Experience Manager をクエリ
以下の例では、mysql モジュールを使用して Adobe Experience Manager への接続を定義し、クエリを実行する方法を示しています。以下の情報が必要です。
- ホスト名またはアドレス、およびポート:MySQL リモーティングサービスが MySQL 接続をリッスンしているマシンとポート
- ユーザー名とパスワード:SQL Gateway の Users タブで認証したユーザーのユーザー名とパスワード
- データベース名:MySQL リモーティングサービス用に設定した DSN
以下のコードでAdobe Experience Manager のデータに接続し、クエリの実行を開始できます。
var mysql = require('mysql');
var connection = mysql.createConnection({
host : 'localhost',
database : 'CData AdobeExperienceManager Sys',
port : '3306',
user : 'mysql_user',
password : 'test'
});
connection.connect();
connection.query('SELECT * FROM Content', function(err, rows, fields) {
if (err) throw err;
console.log(rows);
});
connection.end();