各製品の資料を入手。
詳細はこちら →こんにちは!ウェブ担当の加藤です。マーケ関連のデータ分析や整備もやっています。
この記事では CData ADO.NET Provider for AmazonAthena を使って、Infragistics WPF XamDataGrid に Amazon Athena をデータバインドする方法を説明します。
CData は、Amazon Athena のライブデータにアクセスして連携するための最も簡単な方法を提供します。CData のコネクティビティを利用することで、以下のことが可能になります。
ユーザーはAthena をTableau、Power BI、Excel などの分析ツールと連携させ、好みのツールから詳細な分析を行うことができます。
CData を活用したAmazon Athena の事例については、ブログ記事を参照してください:https://www.cdata.com/blog/amazon-athena-use-cases。
以下のように Infragistics WPF XamDataGrid でAmazon Athena から取得したデータを表示するアプリケーションを作成します。
まず、VisualStudioを立ち上げて、WPFアプリのプロジェクトを作成します。
今回はデータを柔軟に取り出せるように、CData ADO.NET ProviderにSQLを渡すためのTextBoxと実行用のボタンを配置しました。
この段階でのXAMLは以下のようになっています。
次に「XamDataGrid」を配置します。 Infragistics WPF UI コンポーネントをインストールしている場合、ツールボックスに以下のように表示されます。
これをデザイナー画面で以下のように配置しました。
併せて、任意の名称(xamDataGrid としました)、DataSource は{Binding} を指定し、フィルター機能を使えるように「Custom:FieldSettings」に「AllowRecordFiltering="true"」「AllowSummaries="True" 」を追加しました。
また、サンプルプログラムではデザインテーマの「Theme="Metro"」も設定しています。このあたりはお好みでどうぞ。
最後に CData Amazon Athena ADO.NET Provider への接続部分を作成します。
まずは参照設定からCData Amazon Athena ADO.NET Provider のライブラリである「System.Data.CData.AmazonAthena.dll」を追加します。
その後、名前空間に「System.Data.CData.AmazonAthena」を追加し
using System.Data.CData.AmazonAthena;
ボタンをクリックした時にTextBoxからSQL文を取得し、Amazon Athena からデータを取得する処理を記述します。この記述方法は以下のヘルプに記載されているものがほぼそのままです。
using System.Data;
using System.Data.CData.AmazonAthena;
using System.Windows;
namespace CData.XamDataGrid.GropingListApp
{
///
/// MainWindow.xaml の相互作用ロジック
///
public partial class MainWindow : Window
{
public MainWindow()
{
InitializeComponent();
sqlTextBox.Text = "SELECT * FROM Samples";
}
private void ExecuteButton_Click(object sender, RoutedEventArgs e)
{
string connectionString = "AccessKey='a123';SecretKey='s123';Region='IRELAND';Database='sampledb';S3StagingDirectory='s3://bucket/staging/';";
using (var connection = new D365SalesConnection(connectionString))
{
var dataAdapter = new AmazonAthenaDataAdapter(
sqlTextBox.Text, connection);
var table = new DataTable();
dataAdapter.Fill(table);
this.DataContext = table.Rows;
}
}
}
}
通常のWebAPIをそのまま実装した場合、自身でWebAPIリクエストの処理から認証部分、「XamDataGrid」渡すデータ構造の構成まで定義しなければいけませんが、これらコンポーネントの活用により省力化してアプリケーションを開発できます。
このように AmazonAthena 内のデータを API を書くことなく XamDataGrid 上で処理することができるようになります。
サポートされるSQL についての詳細は、ヘルプドキュメントの「サポートされるSQL」をご覧ください。テーブルに関する情報は「データモデル」をご覧ください。