各製品の資料を入手。
詳細はこちら →ColdFusion にリアルタイムNetSuite のデータをインポートしてアプリケーションを構築
CData JDBC ドライバを使ってColdFusion にNetSuite のデータをインポートして使用します。
最終更新日:2023-02-02
この記事で実現できるNetSuite 連携のシナリオ
こんにちは!ドライバー周りのヘルプドキュメントを担当している古川です。
Adobe ColdFusion は、Web アプリケーションおよびモバイルアプリケーション開発プラットフォームです。独自のスクリプト言語であるColdFusion Markup Language(CFML)を使用し、データドリブンなWeb サイトを作成したり、REST などのリモートサービスを生成したりすることができます。
ColdFusion とCData JDBC Driver for NetSuite を組み合わせると、ColdFusion のWeb アプリケーションやモバイルアプリケーションを、運用中のNetSuite のデータにリンクできます。 これにより、アプリケーションの堅牢性と完成度を高めることができます。この記事では、JDBC ドライバーを使ってColdFusion マークアップファイルからNetSuite のデータを入力したテーブルを作成する方法について詳しく説明します。
最適化されたデータ処理が組み込まれたCData JDBC ドライバは、リアルタイムNetSuite のデータを扱う上で高いパフォーマンスを提供します。 NetSuite にSQL クエリを発行すると、CData ドライバーはフィルタや集計などのNetSuite 側でサポートしているSQL 操作をNetSuite に直接渡し、サポートされていない操作(主にSQL 関数とJOIN 操作)は組み込みSQL エンジンを利用してクライアント側で処理します。 組み込みの動的メタデータクエリを使用すると、ネイティブのデータ型を使ってNetSuite のデータを操作および分析できます。
NetSuite への接続を設定する
Coldfusion とNetSuite の接続を確立するには、JDBC 接続文字列が必要です。
Netsuite への接続
NetSuite は現在、2つの異なるAPI を提供しています。
- SuiteTalk はNetSuite との通信に使用する、SOAP ベースのより古いサービスです。多くのエンティティを幅広くサポートし、INSERT / UPDATE / DELETE を完全にサポートします。 しかしデータの抽出用ツールは低機能で、SELECT 時のパフォーマンスは極めて低いです。テーブルを結合するよい方法もありません。データのグループ化および集計はこのAPI からは利用できず、 そのためこれらの操作をサポートするには、すべてをクライアントサイドで実行しなければなりません。
- SuiteQL は新しいAPI です。サービスとのSQL ライクな通信方法を実現するため、JOIN の機能はより豊富になり、GROUP BY や集計機能もサポートします。 加えて、抽出したいカラムだけを取得する機能も完全にサポートします。そのため、データを抽出する際のパフォーマンスがSuiteTalk より大幅に向上しています。ただし、サポートされるのはデータの抽出のみです。
NetSuite に接続するには、以下を行う必要があります。
- Schema を設定して、接続に使用するAPI を指定。データを取得するだけの場合は、SuiteQL の使用をお勧めします。データの取得および変更が必要な場合は、SuiteTalk の使用をお勧めします。
- 使用するAPI に適した接続オプションを設定します。(それぞれのAPI で利用可能な接続オプションが異なります。ヘルプドキュメントの「許可の設定」を参照してください。)
Netsuite への認証
SuiteTalk またはSuiteQL
NetSuite は3つの形式のOAuth 認証を提供します。
- トークンベース認証(TBA)は、基本的にOAuth 1.0 で、OAuthAccessToken とOAuthAccessTokenSecret を実行時ではなくNetSuite UI 内で作成します。 TBA は、2020.2 以降のSuiteTalk およびSuiteQL の両方で利用可能です。
- OAuth 2.0 認証は、SuiteQL でのみ利用できます。OAuth 2.0 認証を強制するには、次のいずれかを実行します。
- OAuthVersion を使用するAPI に明示的に設定、または
- Schema をSuiteQL に設定
- OAuth JWT 認証は、OAuth 2.0 クライアント認証フローであり、クライアント認証情報を含むJWT を使用してNetSuite データへのアクセスを要求します。この認証方法は、Schema がSuiteQL に設定されている場合にのみ使用できます。
認証方法の詳細はヘルプドキュメントの「はじめに」を参照してください。
組み込みの接続文字列デザイナー
JDBC URL の作成の補助として、NetSuite JDBC Driver に組み込まれている接続文字列デザイナーが使用できます。JAR ファイルをダブルクリックするか、コマンドラインからjar ファイルを実行します。
java -jar cdata.jdbc.netsuite.jar

データソースを追加してテーブルを作成する
接続を設定したのち、次の手順に従ってはじめにCData JDBC ドライバをColdFusion のlib ディレクトリに追加し、続けて新しいデータソースを追加、接続をテスト、ColdFusion マークアップファイルを作成し、最後にNetSuite のデータとリアルタイム接続してColdFusion Markup Language(CFML)で記述されるテーブルに表示します。
-
JDBC Driver for NetSuite およびlic ファイルを"C:\Program Files\CData\CData JDBC Driver for NetSuite\lib" から"C:\ColdFusion2021\cfusion\wwwroot\WEB-INF\lib"にコピーします。
cdata.jdbc.netsuite.jar cdata.jdbc.netsuite.lic
Note:.lic ファイルをjar ファイルとともにコピーしないと、有効なライセンスがインストールされていないことを示すライセンスエラーが表示されます。 これは評価版、製品版ともに同様です。
-
ColdFusion Administrator インターフェースで「データとサービス」を選択します。
-
「新規のデータソースの追加」を行います。データソース名は、ColdFusion の変数命名規則に従っていればどのような名前でもかまいません。
JDBC ドライバーの場合は、「その他」を選択して「追加」ボタンをクリックします。
-
次に、ドライバーのプロパティを入力します。
- 「JDBC URL」は、次のような形式である必要があります: jdbc:netsuite:|connectionString|
- 典型的な接続文字列は次のようになります:
jdbc:netsuite:Account Id=XABC123456;Password=password;User=user;Role Id=3;Version=2013_1;
- 「ドライバクラス」は次のようになります:cdata.jdbc.netsuite.NetSuiteDriver
- 「ドライバ名」の入力は任意で、これは単にColdFusion Administrator コンソールでデータソースを認識するために使われます。
-
ここで、作成したCDataNetSuiteJDBC データソースの左側にあるチェックマークをクリックして、接続をテストしてください。
データソースのステータスが「OK」になると、使用可能な状態です。
-
次に、ColdFusion Markup ファイル(.cfm)を新規作成し、ColdFusion のwwwroot ディレクトリ("C:\ColdFusion2021\cfusion\wwwroot")に配置します。
次のコードは、データソースにクエリを実行します。
<cfquery name="NetSuiteQuery" dataSource="CDataNetSuiteJDBC"> SELECT * FROM SalesOrder </cfquery>
CFTable を使用すると、HTML で素早くテーブルを出力できます。<cftable query = "NetSuiteQuery" border = "1" colHeaders colSpacing = "2" headerLines = "2" HTMLTable maxRows = "500" startRow = "1"> <cfcol header="<b>CustomerName</b>" align="Left" width=2 text="CustomerName"/> <cfcol header="<b>SalesOrderTotal</b>" align="Left" width=15 text="SalesOrderTotal"/> ... </cftable>
HTML 部分を含むコード全体を以下に掲載します。<html> <head><title>CData Software | NetSuite SalesOrder Table Demo </title></head> <body> <cfoutput>#ucase("NetSuite SalesOrder Table Demo")#</cfoutput> <cfquery name="NetSuiteQuery" dataSource="CDataNetSuiteJDBC"> SELECT * FROM SalesOrder </cfquery> <cftable query = "NetSuiteQuery" border = "1" colHeaders colSpacing = "2" headerLines = "2" HTMLTable maxRows = "500" startRow = "1"> <cfcol header="<b>CustomerName</b>" align="Left" width=2 text="CustomerName"/> <cfcol header="<b>SalesOrderTotal</b>" align="Left" width=15 text="SalesOrderTotal"/> ... </cftable> </body> </html>
-
最後に、デフォルトのポート8500のブラウザでコードをローカルに実行します。これでNetSuite のデータが入力されたテーブルが作成されました!
なお、CData JDBC ドライバはcfqueryparam 要素を使用したパラメータ化クエリもサポートしています。
次に例を示します。
SELECT * FROM Account WHERE name =
今日からはじめましょう
CData JDBC Driver for NetSuite の 30日間無償トライアル をダウンロードして、Adobe ColdFusion でNetSuite と連携したアプリケーションの作成をはじめましょう!ご不明な点があれば、サポートチームにお問い合わせください。