PHP からHDFS にデータ連携。

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

無償トライアル:

ダウンロードへ

製品の詳細情報へ:

HDFS ODBC Driver

HDFS ODBC Driver を使って、ODBC 接続をサポートするあらゆるアプリケーション・ツールからHDFS にデータ連携。

HDFS データにデータベースと同感覚でアクセスして、HDFS データに使い慣れたODBC インターフェースで双方向連携。



CData ODBC driver for HDFS を使って、PHP アプリケーションからHDFS にデータ連携。PHP でのODBC ネイティブサポートを活用。

CData ODBC Driver for HDFS は、PHP アプリケーションからのHDFS データへの連携を可能にします。本記事では、HDFS データをPHP のビルトインODBC 機能でクエリを実行する手順を説明します。

DSN の設定

HDFS に接続するDSN を作成します。

一般的な接続文字列:

Host=sandbox-hdp.hortonworks.com;Port=50070;Path=/user/root;User=root;

ビルトインのデータソースアドミニストレーターでDSN 設定をします。ドライバーのインストールの最後にアドミニストレーターが開きます。ヘルプの「はじめに」でODBC データソースアドミニストレータでHDFS に接続するDSN の設定方法を参照してください。

HDFS への接続の確立

odbc_connect を呼び出して、HDFS への接続を開きます。 odbc_pconnect メソッドでも可能です。コネクションを閉じるには、odbc_close もしくはodbc_close_all を使います。

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

コネクションはodbc_connect で開かれ、スクリプトが終わると終了します。odbc_pconnect メソッドで開いたコネクションは、スクリプトが終わっても開いたままです。これにより同じクレデンシャルであれば他のスクリプトでコネクションを共有することが可能です:

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

エレメントの作成

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

$query = odbc_prepare($conn, "SELECT * FROM Files WHERE FileId = ?");

クエリの実行

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

$conn = odbc_connect("CData ODBC HDFS Source","user","password"); $query = odbc_prepare($conn, "SELECT * FROM Files WHERE FileId = ?"); $success = odbc_execute($query, array('119116'));

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

$conn = odbc_connect("CData ODBC HDFS Source","user","password"); $query = odbc_exec($conn, "SELECT * FROM Files");

結果の処理

odbc_fetch_array ファンクションの結果セット配列としてアクセスします。

$conn = odbc_connect("CData ODBC HDFS data Source","user","password"); $query = odbc_exec($conn, "SELECT * FROM Files"); while($row = odbc_fetch_array($query)){ echo $row["FileId"] . "\n"; }

odbc_result_all ファンクションで、結果セットをHTML テーブルとして表示します。

$conn = odbc_connect("CData ODBC HDFS data Source","user","password"); $query = odbc_prepare($conn, "SELECT * FROM Files WHERE FileId = ?"); $success = odbc_execute($query, array('119116')); if($success) odbc_result_all($query);

サンプルクエリのテスト

スタンドアロンのテスト環境をたちあげる簡単な方法はPHP のビルトインテストサーバーを使うことです。手順はこちらです:

  1. PHP の最新版のバイナリのダウンロード。

  2. フォルダにファイルを入れる。

  3. フォルダを開く。

  4. php.ini-development をphp.ini に変更。

  5. ブラウザからテストスクリプトにアクセスするためのコマンドを実行。

    php -S localhost:8000 -t C:\path-to-your-scripts -c C:\path-to-php\php.ini

他のサンプルクエリ

サポートされているSQL の詳細は、ヘルプドキュメントを参照してください。上のサンプルは、PHP community documentation for all ODBC functions のHDFS に特化したものです。