Node.js で MYOB AccountRight のデータを MySQL データベースとしてクエリ
MYOB AccountRight 用の ODBC Driver の SQL Gateway を使用すると、MySQL インターフェース経由でMYOB AccountRight のデータをクエリできます。以下の手順に従って、SQL Gateway の MySQL リモーティングサービスを起動し、Node.js からクエリを開始してください。
MYOB AccountRight のデータに接続
まだ行っていない場合は、データソース名(DSN)で必要な接続プロパティの値を指定してください。組み込みの Microsoft ODBC データソースアドミニストレーターを使用して DSN を設定できます。これはドライバーインストールの最後のステップでもあります。Microsoft ODBC データソースアドミニストレーターを使用して DSN を作成・設定する方法については、ヘルプドキュメントの「はじめに」の章を参照してください。
MYOB への接続
MYOB 会社ファイルに接続するには、CompanyFileId をデータを取得したい会社ファイルのID に設定します。指定しない場合は、最初に返された会社ファイルのID(アルファベット順にソート)が使用されます。
この接続プロパティは、CompanyFiles ビューを除くすべてのテーブルおよびビューにアクセスするために必要です。CompanyFiles ビューは、アカウントに紐づく会社ファイル(およびその関連ID)を表示するために使用できます。会社ファイルのID がわからない場合は、このビューを使用してください。
次のプロパティを追加設定します。
| オンプレミスインスタンス | Instance:OnPremises |
| AuthScheme:Basic | |
| User:会社のファイルに紐づいているユーザー名。会社ファイルを作成すると、Administrator というユーザーアカウントが自動的に作成されます。デフォルトでは、Administrator ユーザーアカウントにはパスワードが割り当てられません。 | |
| InitiateOAuth:OFF。 | |
| URL:MYOB インスタンスのURL。 | |
| クラウドインスタンス | Instance:Cloud |
| AuthScheme:OAuth | |
| InitiateOAuth:GETANDREFRESH。 | |
| User:会社のファイルに紐づいているユーザー名。 | |
| Password:(パスワードが設定されている場合)会社ファイルの認可されたユーザーのパスワード |
OAuth で認証する場合は、さらにヘルプドキュメントを参照してください。
SQL Gateway を設定
SQL Gateway 概要を参照して、MYOB AccountRight のデータ を仮想 MySQL データベースとして接続を設定してください。クライアントからの MySQL リクエストをリッスンする MySQL リモーティングサービスを設定します。サービスは SQL Gateway UI で設定できます。

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