Odoo のデータをDevExpress Data Grid にデータバインドする。

加藤龍彦
加藤龍彦
デジタルマーケティング
Odoo 用の CData ADO.NET プロバイダーをDevExpress Windows Forms とWeb コントロールとともに使用し、Odoo をチャートに入力します。

Odoo 用の CData ADO.NET プロバイダーはサードパーティーコントロールで使うことのできる通常のADO.NET データベースアクセスコンポーネントを実装しています。データバインドするための通常のADO.NET プロセスに従うことで、UI コントロールから実データへの双方向アクセスを可能にします。 この記事では、CData を使ってDevExpress Windows Forms とウェブコントロールにデータバインドする方法を説明します。ここでは、最新のデータを表示するチャートにデータバインドします。

接続するには、URL にOdoo インスタンスURL、User およびAPIToken にユーザー資格情報、Database にOdoo データベース名を設定します。 API トークン(Odoo 14 以降でのみ利用可能)を使用していない場合、代わりにAPIToken フィールドにパスワードを直接入力することができます。

接続方法の詳細は、ヘルプドキュメントの「はじめに」セクションを参照してください。

Windows Forms コントロール

下のコードでは、Odoo でDevExpress のチャートに追加する方法を説明します。OdooDataAdapter はチャートコントロールのSeries プロパティにバインドします。コントロールのDiagram プロパティはx 軸とy 軸をカラム名として定義します。

using (OdooConnection connection = new OdooConnection(
"User=MyUser;APIToken=MyToken;URL=http://MyOdooSite/;Database=MyDatabase")) {
  OdooDataAdapter dataAdapter = new OdooDataAdapter(
  "SELECT name, email FROM res_users", connection);

  DataTable table = new DataTable();
  dataAdapter.Fill(table);
  DevExpress.XtraCharts.Series series = new DevExpress.XtraCharts.Series();
  chartControl1.Series.Add(series);
  DataTable table = new DataTable();
  series.ValueDataMembers.AddRange(new string[] { "email" });
  series.ArgumentScaleType = DevExpress.XtraCharts.ScaleType.Qualitative;
  series.ArgumentDataMember = "name";
  series.ValueScaleType = DevExpress.XtraCharts.ScaleType.Numerical;
  chartControl1.Legend.Visibility = DevExpress.Utils.DefaultBoolean.False;
  ((DevExpress.XtraCharts.SideBySideBarSeriesView)series.View).ColorEach = true;
}
The complete code example and the resulting chart.

Web コントロール

下のコードではOdoo でDevExpress Web を操作するための設定方法を説明します。OdooDataAdapter はチャートのSeries プロパティにバインドします。Diagram プロパティはx 軸とy 軸をカラム名として定義します。

using DevExpress.XtraCharts;

using (OdooConnection connection = new OdooConnection(
"User=MyUser;APIToken=MyToken;URL=http://MyOdooSite/;Database=MyDatabase"))
{
  OdooDataAdapter OdooDataAdapter1 = new OdooDataAdapter("SELECT name, email FROM res_users", connection);
  DataTable table = new DataTable();
  OdooDataAdapter1.Fill(table);
  DevExpress.XtraCharts.Series series = new Series("Series1", ViewType.Bar);
  WebChartControl1.Series.Add(series);
  DataTable table = new DataTable();
  series.ValueDataMembers.AddRange(new string[] { "email" });
  series.ArgumentScaleType = ScaleType.Qualitative;
  series.ArgumentDataMember = "name";
  series.ValueScaleType = ScaleType.Numerical;
  ((DevExpress.XtraCharts.SideBySideBarSeriesView)series.View).ColorEach = true;
}
An ASP.NET application created with the ADO.NET Provider and the DevExpress Web Forms control.(Salesforce is shown.)

はじめる準備はできましたか?

Odoo Data Provider の無料トライアルをダウンロードしてお試しください:

 ダウンロード

詳細:

Odoo Icon Odoo ADO.NET Provider お問い合わせ

Odoo ERP のSales Orders、Purchase Orders、Accounts データに連携する.NET アプリケーションを素早く、簡単に開発できる便利なドライバー。