PowerBuilder からSAP SuccessFactors LMS のデータに接続してみた
CData ADO.NET providers は、PowerBuilder を含むMicrosoft .NET をサポートするあらゆるプラットフォームまたは開発テクノロジーから使用できる、使いやすい標準準拠のデータプロバイダーです。 この記事では、CData ADO.NET Provider for SAPSuccessFactorsLMS をPowerBuilder で使う方法について説明します。
CData ADO.NET Provider for SAPSuccessFactorsLMS を使ってデータを取得し読み書きを実行する基本的なPowerBuilder アプリケーションを作成する方法について説明します。
- 新規WPF Window Application ソリューションで、接続プロパティに必要なすべてのビジュアルコントロールを追加します。一般的な接続文字列は次のとおりです:
User=username;CompanyId=CompanyId;Url=https://api4.successfactors.com;InitiateOAuth=GETANDREFRESH;
SAP SuccessFactors LMS は OAuth 認証を使用します。接続する前に、SAP SuccessFactors LMS アカウントに紐づけた OAuth アプリケーションを構成する必要があります。
接続するには、以下のプロパティを設定してください。
- User: SAP SuccessFactors LMS のユーザー名。
- CompanyId: SAP SuccessFactors の会社 ID。
- Url: SAP SuccessFactors API の URL(例: https://api4.successfactors.com)。
- OAuthClientId: カスタム OAuth アプリケーション登録時に割り当てられたクライアント ID。
- OAuthClientSecret: カスタム OAuth アプリケーション登録時に割り当てられたクライアントシークレット。
カスタム OAuth アプリの作成と OAuth の使用方法については、ヘルプドキュメントの「はじめに」を参照してください。
- .NET コントロールからDataGrid コントロールを追加します。
-
DataGrid コントロールのカラムを設定します。Account テーブルからいくつかのカラムを以下に示します:
<DataGrid AutoGenerateColumns="False" Margin="13,249,12,14" Name="datagrid1" TabIndex="70" ItemsSource="{Binding}"> <DataGrid.Columns> <DataGridTextColumn x:Name="idColumn" Binding="{Binding Path=Id}" Header="Id" Width="SizeToHeader" /> <DataGridTextColumn x:Name="nameColumn" Binding="{Binding Path=ItemID}" Header="ItemID" Width="SizeToHeader" /> ... </DataGrid.Columns> </DataGrid> - CData ADO.NET Provider for SAPSuccessFactorsLMS アセンブリへの参照を追加します。
DataGrid 接続
ビジュアルエレメントが設定されたら、Connection、Command、およびDataAdapter のような標準のADO.NET オブジェクトを使ってSQL クエリの結果をDataTable に表示することができます:
System.Data.CData.SAPSuccessFactorsLMS.SAPSuccessFactorsLMSConnection conn conn = create System.Data.CData.SAPSuccessFactorsLMS.SAPSuccessFactorsLMSConnection(connectionString) System.Data.CData.SAPSuccessFactorsLMS.SAPSuccessFactorsLMSCommand comm comm = create System.Data.CData.SAPSuccessFactorsLMS.SAPSuccessFactorsLMSCommand(command, conn) System.Data.DataTable table table = create System.Data.DataTable System.Data.CData.SAPSuccessFactorsLMS.SAPSuccessFactorsLMSDataAdapter dataAdapter dataAdapter = create System.Data.CData.SAPSuccessFactorsLMS.SAPSuccessFactorsLMSDataAdapter(comm) dataAdapter.Fill(table) datagrid1.ItemsSource=table.DefaultView
上のコードは、指定したクエリからDataGrid にデータをバインドできます。