Lazarus Pascal IDE で NetSuite のデータを簡単に統合
Lazarus Pascal IDE は、クロスプラットフォームアプリケーションを構築するための強力で無料のオープンソース開発環境です。CData ODBC Driver for NetSuite を使用すれば、NetSuite のデータ をシームレスに統合してクエリを実行でき、Lazarus Pascal IDE アプリケーション内でリアルタイムのインサイトを活用して、レポート、ダッシュボード、ワークフローを強化できます。
本記事では、接続のセットアップから Lazarus Pascal IDE でリアルタイムの NetSuite データを活用するまでの包括的な手順をご紹介します。レポート、ダッシュボード、複雑なワークフローを構築する際に、アプリケーション内でリアルタイムのインサイトと機能を実現するためのツールを習得できます。
NetSuite データ連携について
CData は、Oracle NetSuite のライブデータにアクセスし、統合するための最も簡単な方法を提供します。お客様は CData の接続機能を以下の目的で使用しています:
- Standard、CRM、OneWorld を含む、すべてのエディションの NetSuite にアクセスできます。
- SuiteTalk API(SOAP ベース)のすべてのバージョンと、SQL のように機能し、より簡単なデータクエリと操作を可能にする SuiteQL に接続できます。
- Saved Searches のサポートにより、事前定義されたレポートとカスタムレポートにアクセスできます。
- トークンベースおよび OAuth 2.0 で安全に認証でき、あらゆるユースケースで互換性とセキュリティを確保します。
- SQL ストアドプロシージャを使用して、ファイルのアップロード・ダウンロード、レコードや関連付けのアタッチ・デタッチ、ロールの取得、追加のテーブルやカラム情報の取得、ジョブ結果の取得などの機能的なアクションを実行できます。
お客様は、Power BI や Excel などのお気に入りの分析ツールからライブ NetSuite データにアクセスするために CData ソリューションを使用しています。また、CData Sync を直接使用するか、Azure Data Factory などの他のアプリケーションとの CData の互換性を活用して、NetSuite データを包括的なデータベースやデータウェアハウスに統合しています。CData は、Oracle NetSuite のお客様が NetSuite からデータを取得し、NetSuite にデータをプッシュするアプリを簡単に作成できるよう支援し、他のソースからのデータを NetSuite と統合することを可能にしています。
当社の Oracle NetSuite ソリューションの詳細については、ブログをご覧ください:Drivers in Focus Part 2: Replicating and Consolidating ... NetSuite Accounting Data
はじめに
概要
本記事の手順の概要は以下のとおりです。
- CData ODBC Driver for NetSuite で NetSuite のデータ 用の DSN を必要な接続プロパティで設定します。
- Lazarus で ODBC 接続をセットアップします。TSQLConnector、TSQLQuery、TDataSource、TDBGrid コンポーネントを必要な情報で設定します。
- Main フォームにサンプルコードを記述して、NetSuite のデータ への接続をテストします。
- アプリケーションをコンパイルして実行し、NetSuite のデータ の統合と表示が正常に行われることを確認します。
前提条件
開始する前に、以下の準備が必要です。
CData ODBC Driver で NetSuite DSN を設定
まず、CData ODBC Driver for NetSuite を使用してシステムでNetSuite のデータ用の DSN(データソース名)を設定します。こちらから全機能を備えた 30日間の無償トライアルをダウンロードしてインストールしてください。
インストールが完了したら、ODBC データソースアドミニストレーターを起動します。
- Windows の場合:スタートメニューで ODBC データソースアドミニストレーター を検索してアプリケーションを開きます。
- Mac の場合:アプリケーションを開き、ユーティリティに移動して ODBC Manager を選択します。
- Linux の場合:コマンドラインを使用して ODBC データソースアドミニストレーター を起動するか、インストールされている場合は unixODBC を使用します。
起動したら、CDataNetSuite のデータSource をダブルクリックして、接続を確立するために必要な値を入力します。
NetSuiteへの接続
NetSuite では、2種類のAPI でデータにアクセスできます。どちらのAPI を使用するかは、Schema 接続プロパティで以下のいずれかを選択して指定してください。
- SuiteTalk は、NetSuite との通信に使用されるSOAP ベースの従来から提供されているサービスです。幅広いエンティティをサポートし、INSERT / UPDATE / DELETE の操作も対応しています。ただし、SuiteQL API と比べるとデータの取得速度が劣ります。また、サーバーサイドでのJOIN に対応していないため、これらの処理はCData 製品がクライアントサイドで実行します。
- SuiteQL は、より新しいAPI です。JOIN、GROUP BY、集計、カラムフィルタリングをサーバーサイドで処理できるため、SuiteTalk よりもはるかに高速にデータを取得できます。ただし、NetSuite データへのアクセスは読み取り専用となります。
データの取得のみが目的でしたらSuiteQL をお勧めします。データの取得と変更の両方が必要な場合は、SuiteTalk をお選びください。
NetSuite への認証
CData 製品では、以下の認証方式がご利用いただけます。
- トークンベース認証(TBA)はOAuth1.0に似た仕組みです。2020.2以降のSuiteTalk とSuiteQL の両方で利用できます。
- OAuth 2.0 認証(OAuth 2.0 認可コードグラントフロー)は、SuiteQL でのみご利用いただけます。
- OAuth JWT 認証は、OAuth2.0 クライアント認証フローの一つで、クライアント認証情報を含むJWT を使用してNetSuite データへのアクセスを要求します。
トークンベース認証(OAuth1.0)
トークンベース認証(TBA)は、基本的にOAuth 1.0 の仕組みです。この認証方式はSuiteTalk とSuiteQL の両方でサポートされています。管理者権限をお持ちの方がNetSuite UI 内でOAuthClientId、OAuthClientSecret、OAuthAccessToken、OAuthAccessTokenSecret を直接作成することで設定できます。 NetSuite UI でのトークン作成手順については、ヘルプドキュメントの「はじめに」セクションをご参照ください。
アクセストークンを作成したら、以下の接続プロパティを設定して接続してみましょう。
- AuthScheme = Token
- AccountId = 接続先のアカウント
- OAuthClientId = アプリケーション作成時に表示されるコンシューマーキー
- OAuthClientSecret = アプリケーション作成時に表示されるコンシューマーシークレット
- OAuthAccessToken = アクセストークン作成時のトークンID
- OAuthAccessTokenSecret = アクセストークン作成時のトークンシークレット
その他の認証方法については、ヘルプドキュメントの「はじめに」をご確認ください。
新しい GUI プロジェクトを作成
- Lazarus IDE を起動します。
- File > New > Application に移動して、Main フォームを持つ新しい GUI プロジェクトを作成します。
フォームに必要な接続コンポーネントを追加
- View > Component > Palette に移動し、左下の Keep open にチェックを入れて、コンポーネントウィンドウを常に開いた状態に保ちます。
-
以下のコンポーネントを検索し、右下の Use をクリックして Main フォーム Form1 に追加します。
- TSQLConnector
- TSQLTransaction
- TSQLQuery
- TDataSource
- TDBGrid
TSQLConnector コンポーネントの設定
Lazarus Pascal IDE の TSQLConnector コンポーネントは、アプリケーションと各種データベースまたはデータベース API との接続を容易にします。設定方法は以下のとおりです。
- Main フォームで TSQLConnector コンポーネントを選択します。
- オブジェクトインスペクターがまだ開いていない場合は、View > Object Inspector から開きます。
- 左側のオブジェクトインスペクターで、Properties セクションの以下のプロパティを設定します。
プロパティ 値 Connected True Driver ODBC DatabaseName DSN 名(例:CData NetSuite Source) UserName データベースのユーザー名 Password データベースのパスワード HostName NetSuite URL またはローカルデータベースの場合は localhost LoginPrompt False Transaction TSQLTransaction コンポーネントを選択
認証情報にセキュリティトークンが必要な場合は、以下の手順に従ってください。
- Lazarus Pascal IDE で Main Form をダブルクリックしてコードエディタを開きます。
- procedure TForm1.FormCreate(Sender: TObject); セクションを見つけます。
- begin キーワードの下に以下のコードを貼り付けます。'your_security_token' を実際のセキュリティトークンに置き換えてください。
SQLConnector1.Params.Values ['Password'] := SQLConnector1.Params.Values ['Password'] + 'your_security_token';
TSQLQuery コンポーネントの設定
Lazarus Pascal IDE の TSQLQuery コンポーネントは、クエリ用の SQL コードを受け取り、データベースからデータを取得することで、データ操作を簡素化します。以下の情報を使用して設定してください。
- Main フォームで TSQLQuery コンポーネントを選択します。
- オブジェクトインスペクターの Properties セクションで以下のプロパティを設定します。
プロパティ 値 Active True DataBase TSQLConnector コンポーネントの名前を選択 SQL(3つの点をクリック) クエリ(例:SELECT * FROM SalesOrder) Transaction TSQLTransaction コンポーネント
TDataSource、TDBGrid、TSQLTransaction コンポーネントの設定
Lazarus Pascal IDE の TDataSource コンポーネントは、データセット(例:TSQLQuery)と TDBGrid などのデータ対応コントロールをつなぎ、データの表示と操作を可能にします。TDBGrid はデータを表形式で表示し、TSQLTransaction はトランザクション内でデータベース操作を実行することでデータの整合性を確保します。これら3つのコンポーネントの設定方法は以下のとおりです。
- TDataSource コンポーネントを選択し、DataSet プロパティに TSQLQuery コンポーネントの名前を設定します。
- TDBGrid コンポーネントを選択し、DataSource プロパティに TDataSource コンポーネントを設定します。
- TSQLTransaction コンポーネントを選択し、以下のプロパティを設定します。
- Active:True
- Database:TSQLConnector コンポーネントの名前
接続をテストするコードを追加
接続を正常にテストするには、以下のコードを使用してください。
- Main Form をダブルクリックしてソースエディタを開きます。
- begin キーワードの下、end. キーワードの前に以下のコードを追加します。
procedure TForm1.FormCreate(Sender: TObject);
begin
// Code for your Security Token
SQLConnector1.Params.Values ['Password'] :=
SQLConnector1.Params.Values ['Password'] + 'your_security_token';
try
SQLConnector1.Open;
ShowMessage('Connection successful!');
except
on E: Exception do
ShowMessage('Error: ' + E.Message);
end;
try
SQLQuery1.Open;
if SQLQuery1.IsEmpty then
ShowMessage('No data found.')
else
ShowMessage('Data loaded successfully.');
except
on E: Exception do
ShowMessage('Error: ' + E.Message);
end;
end;
end.
アプリケーションをコンパイルして実行
プロジェクトを保存します。Run > Compile、続いて Run に移動するか、ショートカット F9 を使用してアプリケーションを実行します。
次のステップ:データを活用してみよう
データが Lazarus に正常にインポートされたので、その可能性を最大限に活用するためのアイデアをご紹介します。
- TDBGrid を拡張:TDBGrid をカスタマイズして、ソート、編集、特定の行のハイライト表示を有効にしましょう。
- データを可視化:TChart などのコンポーネントを使用して、直感的なデータ表現のためのグラフやチャートを作成しましょう。
- フィルタと検索:TDBFilter などのコンポーネントを使用するか、カスタムフィルタロジックを実装して、ユーザーが関連するデータにすばやく集中できるようにしましょう。ユーザー入力用の TEdit コンポーネントを追加し、フィルタ機能にリンクさせます。
- データをエクスポート:TSVExport や TFileStream コンポーネントを活用して、データを CSV や Excel などの形式で保存し、共有や他のシステムへの統合に利用しましょう。
- 計算を実行:TFPCustomDataSet やデータセットの組み込み機能を使用して、合計、平均、その他の指標を計算しましょう。結果を TLabel に表示したり、TDBGrid に追加できます。
- フォームとレポートを作成:TForm と TDBEdit を使用してユーザー操作用のインタラクティブなフォームを設計しましょう。レポートには、RLReport や FastReport などのコンポーネントを統合して、プロフェッショナル品質のレポートを生成・印刷できます。
これらの拡張機能で、データドリブンアプリケーションを次のレベルに引き上げましょう!
CData で Lazarus のデータ接続を簡素化
Lazarus Pascal 内でリアルタイムのNetSuite のデータの可能性を最大限に引き出しましょう。ワークフローを効率化し、生産性を高め、これまでにないシームレスな統合を体験してください。
今すぐ無償トライアルを開始して、データとの接続と作業の方法を変革しましょう!