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

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

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

Acumatica のデータに接続

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

Acumatica 接続プロパティの取得・設定方法

Acumatica への接続

Acumatica データソースに接続するには、次の接続プロパティを指定する必要があります。

  • URL:(必須)Acumatica ERP インスタンスのベースURL。例:https://domain.acumatica.com/
  • Schema:(オプション)異なるデータを含む2つのスキーマがあります。デフォルトはREST で、Acumatica REST コントラクトベースのAPI を使用し、OData スキーマはAcumatica OData API を使用します。OData スキーマはAcumatica Generic Inquiries へのクエリに使用されます。
  • Company:(一部必須)会社名またはテナント名に設定。Schema がOData に設定されている場合は必須です。
  • EndpointVersion:(オプション)Web Services エンドポイントのバージョン。例:24.200.001。これはREST スキーマにのみ適用されます。
  • EndpointName:(オプション)Web Services エンドポイントの名前。例:Default。これはREST スキーマにのみ適用されます。
詳細はヘルプドキュメントの「接続の確立」セクションを参照してください。

Acumatica への認証

Acumatica データソースへの接続に使用できる認証方法は2つあります。Basic およびOAuth です。 Basic 認証では、AuthSchemeBasic に設定し、UserPassword をログイン資格情報に設定します。 OAuth 認証については、ヘルプドキュメントの「接続の確立」セクションにある「OAuth」を参照してください。

SQL Gateway を設定

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

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

Node.js から Acumatica をクエリ

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

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

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

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

connection.end();

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

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

 ダウンロード

詳細:

Acumatica Icon Acumatica ODBC Driver お問い合わせ

Acumatica ODBC Driver を使って、ODBC 接続をサポートするあらゆるアプリケーション・ツールからAcumatica データに連携。

Acumatica に標準ODBC Driver インターフェースを使ってRDB と同感覚でアクセス - Accounts、Bills、Customers、Leads などに標準ODBC インターフェースで双方向連携。