PowerShell Cmdlets でSAP Netweaver Gateway データをCSV にエクスポート

詳細情報をご希望ですか?

無償トライアル:

ダウンロードへ

製品の詳細情報へ:

SAP Netweaver Gateway Data Cmdlets

SAP Netweaver Gateway データにリアルタイム連携を実現するPowerShell Cmdlets。Cmdlets を使って、SQL Server と同感覚で多様なデータにリアルタイムアクセス。



標準PowerShell cmdlets を使ってSAP Netweaver Gateway テーブルにアクセスして、CSV にエクスポート。

CData Cmdlets Module for SAP Netweaver Gateway は、直感的なSAP Netweaver Gateway データ連携を提供する標準cmdlet です。 本記事では、SAPGateway Cmdlets を使ったサンプルを提供します。

SAP Netweaver Gateway への接続を設定

SAP Gateway はBasic 認証とOAuth 2.0 認証の両方を許可します。Basic 認証を使用して自分のアカウントに接続するか、OAuth を使用して他のユーザーが彼らのアカウントでサービスからデータを取得できるようにすることができます。基本となる認証情報に加え、SAP Gateway テーブルへのアクセスには以下の追加プロパティが必要です。

  • Url: 環境のURL、またはサービスの完全URL に設定。例えば、完全URL は次のようになります:https://sapes5.sapdevcenter.com/sap/opu/odata/IWBEP/GWSAMPLE_BASIC/。この例では、環境URL は次のようになります:https://sapes5.sapdevcenter.com。
  • Namespace: 適切なService Namespace を設定。先ほどの例では、IWBEP が名前空間です。サービスへの完全URL が指定されている場合は任意です。
  • Service: データを取得するサービスに設定。先ほどの例では、サービスはGWSAMPLE_BASIC です。完全URL が指定されている場合は必須ではありません。

Basic 認証での認証

Basic 認証では、自分のログインクレデンシャルを使用して接続します。次のプロパティを設定します。

  • User: これはSAP Gateway へのログインに使用するユーザー名です。
  • Password: これはSAP Gateway へのログインに使用するパスワードです。

OAuth 認証での認証

ユーザー資格情報の接続プロパティを設定せずに接続できます。 接続すると、本製品はデフォルトブラウザでSAP Gateway OAuth エンドポイントを開きます。ログインして、本製品にアクセス許可を与えます。本製品が以下のOAuth プロセスを完了します。 他のOAuth 認証フローについては、ヘルプドキュメントの「OAuth 認証の使用」を参照してください。

$conn = Connect-SAPGateway  -User "$User" -Password "$Password" -URL "$URL"

SAP Netweaver Gateway データを取得してCSV にパイプライン

次の手順で、SalesOrderLineItems テーブルデータを取得して、結果をCSV ファイルにエクスポートします:

Select-SAPGateway -Connection $conn -Table SalesOrderLineItems | Select -Property * -ExcludeProperty Connection,Table,Columns | Export-Csv -Path c:\mySalesOrderLineItemsData.csv -NoTypeInformation

このように、Select-SAPGateway から取得した結果を、Select-Object cmdlet に流し、Export-Csv cmdlet に渡す前にいくつかのプロパティを除外しています。これは、CData Cmdlets が接続情報、テーブル、およびカラム情報が結果セットのそれぞれの"行"に挿入されるためです。それらの情報を表示したくない場合に、Export-Csv cmdlet に渡す前に除外を先に行い、それからCSV ファイルにエクスポートします。。

CData Cmdlets から、次のCmdlets にデータをパイプラインするところでは、接続、テーブル、カラムの情報が必要です。

データの削除

以下のように、指定に合致するレコードを削除することができます:

Select-SAPGateway -Connection $conn -Table SalesOrderLineItems -Where "Quantity = 15" | Remove-SAPGateway

データの挿入と更新

CData Cmdlets は、データの加工やクレンジングを行うことができます。以下の手順では、CSV ファイルのデータを、挿入対象のオブジェクトに同じレコードが存在するかを確認した上で、存在する場合にはデータの更新、存在しない場合にはデータの挿入を行います。

Import-Csv -Path C:\MySalesOrderLineItemsUpdates.csv | %{
  $record = Select-SAPGateway -Connection $SAPGateway -Table SalesOrderLineItems -Where ("Id = `'"+$_.Id+"`'")
  if($record){
    Update-SAPGateway -Connection $sapgateway -Table SalesOrderLineItems -Columns ("ProductID","Quantity") -Values ($_.ProductID, $_.Quantity) -Where ("Id = `'"+$_.Id+"`'")
  }else{
    Add-SAPGateway -Connection $sapgateway -Table SalesOrderLineItems -Columns ("ProductID","Quantity") -Values ($_.ProductID, $_.Quantity)
  }
}

このように、CData Cmdlets でデータ連携をシンプルに構成できます。Cmdlets では、モジュールのインストール、接続プロパティの設定だけで、データ連携の構築を始めることができます。是非、CData PowerShell Cmdlets の無償試用版をダウンロードして、シンプルかつパワフルなデータ連携を体感してください。