Deprecated: The each() function is deprecated. This message will be suppressed on further calls in /home/zhenxiangba/zhenxiangba.com/public_html/phproxy-improved-master/index.php on line 456
PHP: MaxDB PHP 拡張モジュール - Manual
[go: Go Back, main page]

PHP
downloads | documentation | faq | getting help | mailing lists | reporting bugs | php.net sites | links | conferences | my php.net

search for in the

maxdb_affected_rows" width="11" height="7"/> <tanh
Last updated: Thu, 31 May 2007

view this page in

LXXXII. MaxDB PHP 拡張モジュール

導入

MaxDB PHP 拡張モジュールにより、MaxDB 7.5.0 以降にアクセスできるようになります。 MaxDB データベースサーバについての詳細な情報は » http://www.mysql.com/products/maxdb/ で得られます。

MaxDB PHP 拡張モジュールは、MySQL の mysqli 拡張モジュールと互換性があります。 これらの間にはほんの少しの違いしかなく、その違いは MaxDB と MySQL の違いに基づくものです。

mysqli との主な相違点は、以下のようになります。

maxdb_character_set_name() - ascii あるいは unicode しか返しません。
maxdb_get_client_info() - 異なるバージョン文字列を返します。
maxdb_get_client_version() - 異なるバージョン文字列を返します。
maxdb_get_host_info() - localhost あるいはホスト名を返します。
maxdb_get_server_info() - 異なるバージョン文字列を返します。
maxdb_get_server_version() - 異なるバージョン文字列を返します。
maxdb_kill() - 単にセッションを切断するだけです。
maxdb_multi_query() - 複数の SQL 文を扱うことはできません。
maxdb_next_result() - 常に false を返します。
maxdb_options() - サポートするオプションが異なります。
maxdb_report() - サポートする繰り返しモードが異なります。
maxdb_stat() - 異なるシステム状態文字列を返します。
maxdb_stmt_store_result() - MaxDB では不要です。
maxdb_store_result() - MaxDB では不要です。

MaxDB についてのドキュメントは » http://dev.mysql.com/doc/maxdb/ にあります。

要件

これらの関数を使用するには、MaxDB のサポートを有効にして PHP をコンパイルする必要があります。さらに、MaxDB サーバにアクセスするために MaxDB SQLDBC ランタイムライブラリが必要です。

MaxDB SQLDBC についてのドキュメントは » http://dev.mysql.com/doc/maxdb/ にあります。

MaxDB SQLDBC パッケージは » http://dev.mysql.com/downloads/maxdb/clients.html からダウンロードします。

インストール手順

設定オプション --with-maxdb[=DIR] を使用すると、PHP から MaxDB データベースへのアクセス機能が有効となります。 [DIR] には、MaxDB SQLDBC パッケージのインストールされているディレクトリを指定します。

Windows ユーザは、php.ini の中で php_maxdb.dll を有効にする必要があります。

実行時設定

php.ini の設定により動作が変化します。

表 156. MaxDB 設定オプション

名前デフォルト変更の可否変更履歴
maxdb.default_hostNULLPHP_INI_ALL 
maxdb.default_dbNULLPHP_INI_ALL 
maxdb.default_userNULLPHP_INI_ALL 
maxdb.default_pwNULLPHP_INI_ALL 
maxdb.long_readlen"200"PHP_INI_ALL 

PHP_INI_* 定数の詳細および定義については 付録 I. php.ini ディレクティブ を参照してください。

以下に設定ディレクティブに関する 簡単な説明を示します。

maxdb.default_host string

データベースサーバへの接続時、ホスト名が指定されていない場合に 使用するデフォルトのホスト。

maxdb.default_db string

データベースが指定されていない場合に、 接続時に使用するデフォルトのサーバデータベース。

maxdb.default_user string

データベースサーバへの接続時、ユーザ名が指定されていない場合に 使用するデフォルトのユーザ名。

maxdb.default_pw string

データベースサーバへの接続時、パスワードが指定されていない場合に 使用するデフォルトのパスワード。

maxdb.long_readlen integer

MaxDB データベースサーバからロングデータを取得した場合に、 クライアントに転送される最大バイト数のデフォルト値。

定義済みクラス

maxdb

PHP と MaxDB データベースとの間の接続を表します。

コンストラクタ

  • maxdb - 新しい maxdb オブジェクトを作成する

メソッド

  • autocommit - データベースの変更内容の自動コミット機能を有効あるいは無効にする

  • change_user - 指定したデータベース接続のユーザ名を変更する

  • character_set_name - データベース接続のデフォルト文字セットを返す

  • close - 事前にオープンされた接続を閉じる

  • commit - 現在のトランザクションをコミットする

  • connect - MaxDB データベースサーバへの新しい接続をオープンする

  • debug - デバッグ操作を実行する

  • dump_debug_info - デバッグ情報を出力する

  • get_client_info - クライアントのバージョンを返す

  • get_host_info - 使用している接続の型を返す

  • get_server_info - MaxDB サーバのバージョンを返す

  • get_server_version - MaxDB サーバのバージョンを返す

  • init - maxdb オブジェクトを初期化する

  • info - 直近で実行されたクエリの情報を取得する

  • kill - MaxDB スレッドの終了をサーバに要求する

  • multi_query - 複数のクエリを実行する

  • more_results - 現在実行している複数クエリに次の結果があるかどうかを調べる

  • next_result - 現在実行している複数クエリの次の結果を読み込む

  • options - オプションを設定する

  • ping - サーバとの接続を確認し、接続されていない場合には再接続する

  • prepare - SQL クエリを準備する

  • query - クエリを実行する

  • real_connect - MaxDB データベースサーバとの接続をオープンする

  • escape_string - 接続の現在の文字セットを考慮したうえで、SQL 文で使用する文字列の特殊文字をエスケープする

  • rollback - 現在のトランザクションをロールバックする

  • select_db - デフォルトのデータベースを選択する

  • ssl_set - ssl パラメータを設定する

  • stat - 現在のシステム状態を取得する

  • stmt_init- maxdb_stmt_prepare で使用するステートメントを初期化する

  • store_result - 最後に実行したクエリの結果を転送する

  • use_result - 最後に実行したクエリのバッファ化されていない結果を転送する

  • thread-safe - スレッドセーフかどうかを返す

プロパティ

  • affected_rows - 直前の MaxDB 操作で変更された行数を取得する

  • client_info - MaxDB クライアントのバージョンを文字列で返す

  • client_version - MaxDB クライアントのバージョンを整数で返す

  • errno - 直近の関数コールのエラーコードを返す

  • error - 直近の関数コールのエラー文字列を返す

  • field_count - 直近のクエリのカラム数を返す

  • host_info - 使用している接続の型を表す文字列を返す

  • info - 直近に実行されたクエリについての情報を取得する

  • insert_id - 直近のクエリで使用した自動生成 ID を返す

  • protocol_version - 使用している MaxDB プロトコルのバージョンを返す

  • sqlstate - 直近のエラーについての SQLSTATE エラーコードを含む文字列を返す

  • thread_id - 現在の接続のスレッド ID を返す

  • warning_count - 直前の SQL 文の実行中に発生した警告の数を返す

maxdb_stmt

プリペアドステートメントを表します。

メソッド

  • bind_param - プリペアドステートメントに変数をバインドする

  • bind_result - 結果を保存するために、プリペアドステートメントに変数をバインドする

  • close - プリペアドステートメントを閉じる

  • data-seek - ステートメントの結果セットの任意の行に移動する

  • execute - プリペアドステートメントを実行する

  • fetch - プリペアドステートメントから結果を取得してバインド変数に保存する

  • free_result - 指定したステートメントハンドルの結果メモリを開放する

  • result_metadata - プリペアドステートメントからメタデータ情報の結果セットを取得する

  • prepare - SQL クエリを準備する

  • send_long_data - データをチャンクに送る

  • close_long_data - long データの送信を終了する

  • reset - プリペアドステートメントをリセットする

  • store_result - プリペアドステートメントから結果セット全体をバッファに保存する

プロパティ

  • affected_rows - 直近のステートメントの実行で変更された行数を返す

  • errno - 直近のステートメント関数のエラーコードを返す

  • errno - 直近のステートメントkな数のエラーメッセージを返す

  • param_count - 指定したプリペアドステートメントのパラメータの数を返す

  • sqlstate - 直近のステートメント関数の SQLSTATE エラーコードを含む文字列を返す

maxdb_result

データベースに対するクエリによって取得した結果セットを表します。

メソッド

  • close - 結果セットを閉じる

  • data_seek - 内部結果ポインタを移動する

  • fetch_field - 結果セットからカラム情報を取得する

  • fetch_fields - 結果セットの全てのカラムの情報を取得する

  • fetch_field_direct - 指定したカラムの情報を取得する

  • fetch_array - 連想配列、数値添字配列あるいはその両方で結果の行を取得する

  • fetch_assoc - 結果の行を連想配列で取得する

  • fetch_object - 結果の行をオブジェクトとして取得する

  • fetch_row - 結果の行を数値添字の配列で取得する

  • close - 結果のメモリを開放する

  • field_seek - 指定したフィールドオフセットに結果ポインタを移動する

プロパティ

  • current_field - 現在のフィールドポインタのオフセットを返す

  • field_count - 結果セットのフィールド数を返す

  • lengths - カラムの長さの配列を返す

  • num_rows - 結果セットの行数を返す

リソース型

この拡張モジュールではリソースを定義しています。

定義済み定数

以下の定数が定義されています。 この関数の拡張モジュールが PHP 組み込みでコンパイルされているか、 実行時に動的にロードされている場合のみ使用可能です。

以下の定数が、maxdb_options() で使用するために定義されています。これらの定数についての詳細な情報は » http://dev.mysql.com/doc/maxdb/ を参照ください。

表 157. MaxDB PHP クライアント定数

定数説明
MAXDB_COMPNAMESQLDBC ランタイム環境を初期化するために使用するコンポーネント名。
MAXDB_APPLICATIONデータベースに接続しているアプリケーション。
MAXDB_APPVERSIONアプリケーションのバージョン。
MAXDB_SQLMODESQL モード。
MAXDB_UNICODEunicode (UCS2) クライアントによる接続の場合に TRUE、そうでない場合に FALSE。
MAXDB_TIMEOUT データベースへの接続がシステムによって閉じられるまでの 最大無活動時間。
MAXDB_ISOLATIONLEVEL 共有ロックおよび排他ロックを暗黙的に要求/開放するかどうか、 またどのように行うかを指定します。
MAXDB_PACKETCOUNT 接続に使用するリクエストパケットの数。
MAXDB_STATEMENTCACHESIZE 接続内での再利用のためにキャッシュされるプリペアドステートメントの数。
MAXDB_CURSORPREFIX 自動的に命名される結果テーブルに使用するプレフィックス。

maxdb_fetch_array() 関数は、 結果の配列の型を指定するために定数を使用します。 以下の定数が定義されています。

表 158. MaxDB フェッチ定数

定数説明
MAXDB_ASSOC フィールド名をインデックスとする配列で、カラムを返します。
MAXDB_ASSOC_UPPER 大文字に変換したフィールド名をインデックスとする配列で、 カラムを返します。
MAXDB_ASSOC_LOWER 小文字に変換したフィールド名をインデックスとする配列で、 カラムを返します。
MAXDB_BOTH 数値インデックスおよびフィールド名インデックスの両方を含む配列で、 カラムを返します。
MAXDB_NUM フィールドの数値インデックスを持つ配列で、カラムを返します。 インデックスは 0 から始まり、これが結果の最初のフィールドを表します。

MaxDB PHP マニュアルの全ての例は、MaxDB から得られるデモデータベース HOTELDB を使用しています。このデータベースについての情報は » http://dev.mysql.com/doc/maxdb/en/98/11b83fa6b33c17e10000000a114084/frameset.htm で得られます。

MaxDB PHP マニュアルのデータベースを使用するには、チュートリアルのデータを データベースに読み込む必要があります。その後、php.ini の中の maxdb.default_db に、チュートリアルデータを含むデータベースを設定します。

この単純な例では、MaxDB データベースへの接続・クエリの実行・ 結果の行の表示・接続の切断の方法を示します。

例 1118. MaxDB 拡張モジュールの概要

<?php
$link
= maxdb_connect("localhost", "MONA", "RED", "DEMODB");
  
/* 接続を調べます */
if (maxdb_connect_errno()) {
  
printf("接続に失敗しました: %s\n", maxdb_connect_error());
   exit();
}

/* SQL クエリを実行します */
$query = "SELECT * FROM hotel.city";
$result = maxdb_query($link, $query) or die("クエリに失敗しました: " . maxdb_error());

/* 結果を HTML で表示します */
echo "<table>\n";
while (
$line = maxdb_fetch_array($result, MAXDB_ASSOC)) {
    echo
"  <tr>\n";
    foreach (
$line as $col_value) {
        echo
"    <td>$col_value</td>\n";
    }
    echo
"  </tr>\n";
}
echo
"</table>\n";

/* 結果セットを開放します */
maxdb_free_result($result);

/* 接続を閉じます */
maxdb_close($link);
?>

以下の例では、SELECT INTO 文に変数をバインドする方法を示します。

例 1119. SELECT INTO 文の使用例

<?php
$link
= maxdb_connect("localhost", "MONA", "RED", "DEMODB");

/* 接続を調べます */
if (!$link) {
  
printf("接続に失敗しました: %s\n", maxdb_connect_error());
   exit();
}
  
/* SQL クエリを実行します */
$stmt = maxdb_prepare ($link, "SELECT percentage INTO ? FROM hotel.countrylanguage where language = ?");
if (!
$stmt) {
 
printf ("準備に失敗しました: %s\n", maxdb_error($link));
}

$name = "Mbundu";

maxdb_stmt_bind_param($stmt, 'ds', $percentage, $name);
maxdb_stmt_execute($stmt);

printf ("%f\n", $percentage);

maxdb_stmt_close ($stmt);
?>

以下の例では、MaxDB のプロシージャを使用する方法を示します。

例 1120. データベースプロシージャの使用

<?php
$link
= maxdb_connect("localhost", "MONA", "RED", "DEMODB");

/* 接続を調べます */
if (!$link) {
  
printf("接続に失敗しました: %s\n", maxdb_connect_error());
   exit();
}

maxdb_report (MAXDB_REPORT_OFF);
maxdb_query($link,"DROP DBPROC test_proc");
maxdb_report (MAXDB_REPORT_ERROR);

$query = "create dbproc test_proc (INOUT e_text char(72)) AS select * from SYSDBA.DUAL; fetch into :e_text;";

maxdb_query($link, $query);

/* SQL クエリを実行します */
$stmt = maxdb_prepare ($link, "CALL test_proc (?)");
if (!
$stmt) {
 
printf ("準備に失敗しました: %s\n", maxdb_error($link));
}

maxdb_stmt_bind_param($stmt, 's', $result);
maxdb_stmt_execute($stmt);

printf ("%s\n", $result);

maxdb_stmt_close ($stmt);
?>

目次

maxdb_affected_rows — 直前の MaxDB の操作で変更された行数を取得する
maxdb_autocommit — データベースの変更内容の自動コミット機能を有効あるいは無効にする
maxdb_bind_parammaxdb_stmt_bind_param() のエイリアス
maxdb_bind_resultmaxdb_stmt_bind_result() のエイリアス
maxdb_change_user — 指定したデータベース接続のユーザを変更する
maxdb_character_set_name — データベース接続のデフォルトの文字セットを返す
maxdb_client_encodingmaxdb_character_set_name() のエイリアス
maxdb_close_long_datamaxdb_stmt_close_long_data() のエイリアス
maxdb_close — 事前にオープンされたデータベース接続を閉じる
maxdb_commit — 現在のトランザクションをコミットする
maxdb_connect_errno — 直近の接続コールのエラーコードを返す
maxdb_connect_error — 直近の接続エラーについての説明を文字列で返す
maxdb_connect — MaxDB サーバへの新しい接続をオープンする
maxdb_data_seek — 結果ポインタを、結果の任意の行に移動する
maxdb_debug — デバッグ操作を行う
maxdb_disable_reads_from_master — マスタからの読み込みを無効にする
maxdb_disable_rpl_parse — RPL のパースを無効にする
maxdb_dump_debug_info — デバッグ情報をログに出力する
maxdb_embedded_connect — 組み込み MaxDB サーバへの接続をオープンする
maxdb_enable_reads_from_master — マスタからの読み込みを有効にする
maxdb_enable_rpl_parse — RPL のパースを有効にする
maxdb_errno — 直近の関数コールのエラーコードを返す
maxdb_error — 直近のエラーについて説明する文字列を返す
maxdb_escape_stringmaxdb_real_escape_string() のエイリアス
maxdb_executemaxdb_stmt_execute() のエイリアス
maxdb_fetch_array — 結果の行を連想配列、数値添字配列あるいはその両方で取得する
maxdb_fetch_assoc — 結果の行を連想配列として取得する
maxdb_fetch_field_direct — 単一のフィールドのメタデータを取得する
maxdb_fetch_field — 結果セットの次のフィールドを返す
maxdb_fetch_fields — 結果セット内のフィールドを表すリソースの配列を返す
maxdb_fetch_lengths — 結果セットの現在の行のカラムの長さを返す
maxdb_fetch_object — 結果セットの現在の行をオブジェクトとして返す
maxdb_fetch_row — 結果の行を数値添字の配列として取得する
maxdb_fetchmaxdb_stmt_fetch() のエイリアス
maxdb_field_count — 直近のクエリのカラム数を返す
maxdb_field_seek — 結果ポインタを、指定したフィールドオフセットに移動する
maxdb_field_tell — 結果ポインタの現在のフィールドオフセットを取得する
maxdb_free_result — 結果に関連付けられたメモリを開放する
maxdb_get_client_info — MaxDB クライアントのバージョンを文字列で返す
maxdb_get_client_version — MaxDB クライアントの情報を取得する
maxdb_get_host_info — 使用している接続の型を表す文字列を返す
maxdb_get_metadatamaxdb_stmt_result_metadata() のエイリアス
maxdb_get_proto_info — 使用している MaxDB プロトコルのバージョンを返す
maxdb_get_server_info — MaxDB サーバのバージョンを返す
maxdb_get_server_version — MaxDB サーバのバージョンを整数値で返す
maxdb_info — 直近に実行したクエリについての情報を取得する
maxdb_init — MaxDB を初期化し、maxdb_real_connect で使用するリソースを返す
maxdb_insert_id — 直近のクエリで使用した、自動生成 ID を返す
maxdb_kill — MaxDB サーバから切断する
maxdb_master_query — マスタ/スレーブ構成において、クエリをマスタ側で実行することを強制する
maxdb_more_results — 複数クエリの結果の中に結果セットがまだあるかどうかを調べる
maxdb_multi_query — データベース上でクエリを実行する
maxdb_next_result — multi_query の、次の結果を準備する
maxdb_num_fields — 結果のフィールド数を取得する
maxdb_num_rows — 結果の行数を取得する
maxdb_options — オプションを設定する
maxdb_param_countmaxdb_stmt_param_count() のエイリアス
maxdb_ping — サーバとの接続を確認し、接続が確立されていない場合は再接続を試みる
maxdb_prepare — 後で実行するための SQL 文を準備する
maxdb_query — データベース上でクエリを実行する
maxdb_real_connect — MaxDB サーバへの接続をオープンする
maxdb_real_escape_string — 現在の接続の文字セットを考慮したうえで、 SQL 文で使用される文字列中の特殊文字をエスケープする
maxdb_real_query — SQL クエリを実行する
maxdb_report — 内部のレポート関数を有効あるいは無効にする
maxdb_rollback — 現在のトランザクションをロールバックする
maxdb_rpl_parse_enabled — RPL のパースが有効かどうかを調べる
maxdb_rpl_probe — RPL を調べる
maxdb_rpl_query_type — RPL クエリ型を返す
maxdb_select_db — データベースクエリ用のデフォルトデータベースを選択する
maxdb_send_long_datamaxdb_stmt_send_long_data() のエイリアス
maxdb_send_query — クエリを送信する
maxdb_server_end — 埋め込みサーバをシャットダウンする
maxdb_server_init — 埋め込みサーバを初期化する
maxdb_set_optmaxdb_options() のエイリアス
maxdb_sqlstate — 直近の MaxDB 操作の SQLSTATE エラーを返します
maxdb_ssl_set — SSL を使用したセキュアな接続を確立するために使用する
maxdb_stat — 現在のシステム状態を取得する
maxdb_stmt_affected_rows — 直近のステートメントによって変更、削除あるいは挿入された行の数を返す
maxdb_stmt_bind_param — プリペアドステートメントに、変数をパラメータとしてバインドする
maxdb_stmt_bind_result — 結果を保存するために、変数をプリペアドステートメントにバインドする
maxdb_stmt_close_long_datamaxdb_stmt_send_long_data() のシーケンスを終了する
maxdb_stmt_close — プリペアドステートメントを閉じる
maxdb_stmt_data_seek — ステートメントの結果セットの、任意の行に移動する
maxdb_stmt_errno — 直近のステートメントコール時のエラーコードを返す
maxdb_stmt_error — 直近のステートメントコール時のエラー文字列を返す
maxdb_stmt_execute — プリペアドクエリを実行する
maxdb_stmt_fetch — プリペアドステートメントの結果を取得し、バインド変数に格納する
maxdb_stmt_free_result — 指定したステートメントハンドルの結果を保存しているメモリを開放する
maxdb_stmt_init — ステートメントを初期化し、maxdb_stmt_prepare で使用するリソースを返す
maxdb_stmt_num_rows — ステートメントの結果セットの行数を返す
maxdb_stmt_param_count — 指定したステートメントのパラメータ数を返す
maxdb_stmt_prepare — 後で実行するための SQL 文を準備する
maxdb_stmt_reset — プリペアドステートメントをリセットする
maxdb_stmt_result_metadata — プリペアドステートメントから、結果セットのメタデータを返す
maxdb_stmt_send_long_data — データを複数ブロックで送信する
maxdb_stmt_sqlstate — 事前のステートメントの捜査からの SQLSTATE エラーを返す
maxdb_stmt_store_result — プリペアドステートメントから結果を転送する
maxdb_store_result — 直近のクエリから結果セットを転送する
maxdb_thread_id — 現在の接続のスレッド ID を返す
maxdb_thread_safe — スレッドセーフであるかどうかを返す
maxdb_use_result — 結果セットの取得を開始する
maxdb_warning_count — 指定したリンクの直近のクエリで発生した警告の数を返す


add a note add a note User Contributed Notes
MaxDB PHP 拡張モジュール
Sven
25-Feb-2006 05:14
Installation procedure of the maxdb - php module might be a bit troublesome for some part. Me, among others (judjing by forum threads) have managed to get problems when trying to install the maxdb-php module whithout any errorcodes. Making it hard to fix..:) 
however, the ODBC-version of MaxDB / SapDB shouldn't be any troubles installing. There's a guide for this at the page:
http://maxdb.yapabout.com/viewtopic.php?t=21

Ofcourse, then the PHP ODBC should be used, not the MaxDB -php version.

maxdb_affected_rows" width="11" height="7"/> <tanh
Last updated: Thu, 31 May 2007
 
 
show source | credits | sitemap | contact | advertising | mirror sites