製品をチェック

無償トライアル:

無償トライアルへ

製品の情報と無償トライアルへ:

Qoo10 ODBC Driver

Qoo10 ODBC ドライバーは、ODBC 接続をサポートする任意のアプリケーションからライブなQoo10 データに直接接続できる強力なツールです。標準のODBC ドライバーインタフェースを使用して、データベースのようにQoo10 にアクセスし、在庫、商品、受注などの読み出し、書き込み、および更新を実行できます。

データ連携でお困りですか?

お問い合わせ

PHP のネイティブ機能を使ってQoo10 にデータ連携


CData ODBC Driver for Qoo10 を使って、Linux/Unix マシン上でQoo10 データに連携可能なPHP アプリケーションを作成。PHP でのODBC ネイティブサポートを活用します。


古川えりか
コンテンツスペシャリスト

CData ODBC Driver for Qoo10 をLAMP またはWAMP スタックにドロップし、Qoo10 に接続されたWeb アプリケーションを構築します。本記事では、PHP のビルトインODBC 機能でQoo10 データに接続し、クエリを実行して、結果を出力する手順を説明します。

UNIX/Linux マシンでCData ODBC Drivers を使用する

CData ODBC Drivers は、Ubuntu、Debian、RHEL、CentOS、Fedora など、Red Hat およびDebian ベースのさまざまなシステムでサポートされています。また、いくつかライブラリやパッケージが要求されることがありますが、それらの多くはシステムにデフォルトでインストールされています。サポートされているLinux オペレーティングシステムのバージョンと必要なライブラリの詳細については、インストール済みのもの、またはWeb 上にあるヘルプドキュメントの「はじめに」の章を参照してください。

ドライバーマネージャーをインストールする

ドライバーをインストールする前に、システムにドライバーマネージャーがあることを確認してください。この記事では、広くサポートされている無料のオープンソースODBC ドライバーマネージャーであるunixODBC を使用します。

Ubuntu のようなDebian ベースのシステムでは、APT パッケージマネージャーを使用してunixODBC をインストールできます。

$ sudo apt-get install unixODBC unixODBC-dev

Red Hat Linux ベースのシステムの場合は、yum またはdnf を使用してunixODBC をインストールできます。

$ sudo yum install unixODBC unixODBC-devel

unixODBC ドライバーマネージャーは、ドライバーの情報をodbcinst.ini ファイルから、データソースの情報をodbc.ini ファイルから読み取ります。 次のコマンドをターミナルに入力することで、システムの設定ファイルの場所を指定できます。

$ odbcinst -j

コマンドの出力は、登録されたODBC ドライバーおよびODBC データソースの設定ファイルの場所を表示します。 ユーザーデータソースにアクセスできるのは、odbc.ini ファイルがホームフォルダに格納されているユーザーアカウントだけです。システムデータソースには、すべてのユーザーがアクセスできます。 以下に、このコマンドの出力例を示します。

DRIVERS............: /etc/odbcinst.ini SYSTEM DATA SOURCES: /etc/odbc.ini FILE DATA SOURCES..: /etc/ODBCDataSources USER DATA SOURCES..: /home/myuser/.odbc.ini SQLULEN Size.......:8 SQLLEN Size........:8 SQLSETPOSIROW Size.:8

ドライバーをインストールする

標準パッケージ形式(Debian .deb パッケージ形式または.rpm ファイル形式)でドライバーをダウンロードすることができます。ファイルをダウンロードしたら、ターミナルからドライバーをインストールできます。

ドライバーインストーラーはドライバーをunixODBC に登録し、システムDSN を作成します。これは、後にODBC 接続をサポートするツールやアプリケーションで使用できます。

Ubuntu のようなDebian ベースのシステムでは、sudo またはroot で以下のコマンドを実行します。 $ dpkg -i /path/to/package.deb

Red Hat システムまたは.rpms をサポートするその他のシステムの場合は、sudo またはroot で以下のコマンドを実行します。 $ rpm -i /path/to/package.rpm

ドライバーがインストールされたら、unixODBC ドライバーマネージャーを使用し、登録されたドライバーと定義されたデータソースを一覧表示できます。

登録されているドライバーを一覧表示する

$ odbcinst -q -d CData ODBC Driver for Qoo10 ...

定義されたデータソースを一覧表示する

$ odbcinst -q -s CData Qoo10 Source ...

CData ODBC Driver for Qoo10 をunixODBC で使用するには、ドライバーがUTF-16 を使用するように設定されていることを確認します。そのために、インストール場所(通常はcdata.odbc.qoo10.ini)のlib フォルダにある、ドライバー(cdata.odbc.qoo10.ini)のINI ファイルを以下のように編集します。

cdata.odbc.qoo10.ini

... [Driver] DriverManagerEncoding = UTF-16

DSN を変更する

ドライバーのインストールにより、システムDSN が事前定義されます。DSN を変更するには、システムデータソースファイル(/etc/odbc.ini)を編集し、必要な接続プロパティを定義します。さらに、$HOME/.odbc.ini での変更にルートアクセスを必要としない、ユーザー固有のDSN を作成することができます。

Qoo10 に接続するには、ApiKey、Password、およびUser が必要です。

Qoo10 へのアクセスの設定

  • API Key を取得するためには、Qoo10 の営業担当者に依頼する必要があります。
  • Qoo10 営業担当社へ依頼すると後日、API Key が送られてきます。

Qoo10 アカウントの認証

次の接続プロパティを設定して接続します。

  • ApiKey:Qoo10 営業担当者から受け取ったAPI Key を設定。
  • User: にログインするためのユーザーID を設定。
  • Password: にログインするためのパスワードを設定。

/etc/odbc.ini または$HOME/.odbc.ini

[CData Qoo10 Source] Driver = CData ODBC Driver for Qoo10 Description = My Description User = userTest Password = passwordTest ApiKey = YOUR_API_KEY

これらの構成ファイルの使用方法については、オンラインのヘルプドキュメントを参照してください。

接続を確立する

odbc_connect またはodbc_pconnect を呼び出して、Qoo10 への接続を開きます。 接続を閉じるには、odbc_close もしくはodbc_close_all を使います。

$conn = odbc_connect("CData ODBC Qoo10 Source","user","password");

接続はodbc_connect で開かれ、スクリプトが終わると終了します。odbc_pconnect メソッドで開いた接続は、スクリプトが終わっても開いたままです。これにより同じクレデンシャルであれば他のスクリプトで接続を共有することが可能です。スクリプト間で接続を共有することにより、システムリソースを節約し、クエリの実行を高速化できます。

$conn = odbc_pconnect("CData ODBC Qoo10 Source","user","password"); ... odbc_close($conn); //persistent connection must be closed explicitly

プリペアドステートメントを作成する

odbc_prepare を使って、プリペアドステートメントおよびパラメータライズドクエリを作成します。

$query = odbc_prepare($conn, "SELECT * FROM GoodsDetail WHERE ItemQty = ?");

クエリを実行する

Prepared ステートメントをodbc_execute を使って実行します。

$conn = odbc_connect("CData ODBC Qoo10 Source","user","password"); $query = odbc_prepare($conn, "SELECT * FROM GoodsDetail WHERE ItemQty = ?"); $success = odbc_execute($query, array('12'));

Non-Parameterized クエリは、odbc_exec を使います。

$conn = odbc_connect("CData ODBC Qoo10 Source","user","password"); $query = odbc_exec($conn, "SELECT ItemNo, ItemTitle FROM GoodsDetail");

結果の処理

odbc_fetch_array 関数の結果セット配列としてアクセスします。

$conn = odbc_connect("CData ODBC Qoo10 data Source","user","password"); $query = odbc_exec($conn, "SELECT ItemNo, ItemTitle FROM GoodsDetail"); while($row = odbc_fetch_array($query)){ echo $row["ItemNo"] . "\n"; }

odbc_result_all 関数で、結果セットをHTML テーブルとして表示します。

$conn = odbc_connect("CData ODBC Qoo10 data Source","user","password"); $query = odbc_prepare($conn, "SELECT * FROM GoodsDetail WHERE ItemQty = ?"); $success = odbc_execute($query, array('12')); if($success) odbc_result_all($query);

他のサンプルクエリ

ドライバーがサポートしているSQL の詳細は、ヘルプドキュメントを参照してください。上のサンプルは、PHP community documentation for all ODBC functions をQoo10 向けに変更したものです。