PostgreSQL データベースはオープンソースの製品であり、無料で 使用可能です。Postgres は元々 UCB(カリフォルニア大学バークレイ校) コンピュータ・サイエンス学部で開発されたものです。この Postgres は、 現在いくつかの商用データベースにおいてサポートされつつある オブジェクトリレーショナルデータベース的概念の多くの先駆けでした。 Postgres は、SQL92/SQL99 言語サポート・トランザクション・参照整合性・ ストアドプロシージャ・拡張可能な型を提供しています。PostgreSQL は、 バークレイ校での Postgres のオリジナルコードの、オープンソースの 子孫にあたります。
PostgreSQL サポートを使用するには、PostgreSQL 6.5 以降が必要です。 PostgreSQL 8.0 以降では PostgreSQL モジュールの全ての機能を使用可能 です。PostgreSQL は、マルチバイト文字エンコーディングを含む多くの 文字エンコーディングをサポートしています。現在のバージョン及び PostgreSQLに関するより詳細な情報は、 http://www.postgresql.org/ と PostgreSQL Documentation で入手可能です。
PostgreSQLサポートを利用可能とするには、PHPコンパイル時に --with-pgsql[=DIR] を指定することが必要です。 共有オブジェクトモジュールが利用可能な場合、php.ini の extension ディレクティブ または dl() 関数によりPostgreSQLモジュール をロードすることが可能です。
php.ini の設定により動作が変化します。
表 1. PostgreSQL設定オプション
名前 | デフォルト | 変更の可否 | 変更履歴 |
---|---|---|---|
pgsql.allow_persistent | "1" | PHP_INI_SYSTEM | |
pgsql.max_persistent | "-1" | PHP_INI_SYSTEM | |
pgsql.max_links | "-1" | PHP_INI_SYSTEM | |
pgsql.auto_reset_persistent | "0" | PHP_INI_SYSTEM | PHP 4.2.0 以降で有効です。 |
pgsql.ignore_notice | "0" | PHP_INI_ALL | PHP 4.3.0 以降で有効です。 |
pgsql.log_notice | "0" | PHP_INI_ALL | PHP 4.3.0 以降で有効です。 |
以下に設定ディレクティブに関する 簡単な説明を示します。
持続的な Postgres 接続を可能にするかどうか。
プロセス毎の持続的 Postgres 接続の最大数。
持続的接続を含むプロセス毎の Postgres 接続の最大数。
pg_pconnect() で作成した持続的接続の障害を 検出する。少々のオーバーヘッドを要します。
PostgreSQL バックエンドの通知メッセージを無視するかどうか。
PostgreSQL バックエンドの通知メッセージをログに記録するかしないか。 ログに記録するには、PHP ディレクティブ pgsql.ignore_notice を off にする必要があります。
PostgreSQL モジュールで使用されるリソース型は 2 種類あります。ひとつは データベース接続のリンク ID で、もうひとつはクエリの結果を保持する リソースです。
以下の定数が定義されています。 この関数の拡張モジュールが PHP 組み込みでコンパイルされているか、 実行時に動的にロードされている場合のみ使用可能です。
pg_fetch_array() に渡します。 フィールド名と値の連想配列を返します。
pg_fetch_array() に渡します。 フィールド番号と値の数値添字配列を返します。
pg_fetch_array() に渡します。 フィールド値の配列を、数値添字(フィールド番号で)と 連想配列(フィールド名で)の両方で返します。
pg_connect() に渡し、既存の同一接続を無視して 新しい接続を確立させるようにします。
pg_connection_status() から返され、データベースとの 接続が不正な状態になっていることを示します。
pg_connection_status() から返され、データベースとの 接続が正常であることを示します。
pg_lo_seek() に渡します。シーク操作は オブジェクトの先頭から始められます。
pg_lo_seek() に渡します。シーク操作は カレントの位置から始められます。
pg_lo_seek() に渡します。シーク操作は オブジェクトの最後から始められます。
pg_result_status() から返されます。 サーバに送信された文字列が空でした。
pg_result_status() から返されます。 コマンドは正常に終了し、何もデータを返しませんでした。
pg_result_status() から返されます。 コマンドは正常に終了し、データを返しました (SELECT や SHOW など)。
pg_result_status() から返されます。 (サーバからの)データのコピーが始まりました。
pg_result_status() から返されます。 (サーバへの)データのコピーが始まりました。
pg_result_status() から返されます。 サーバからの応答を判別できませんでした。
pg_result_status() から返されます。 致命的ではないエラー(通知や警告など)が発生しました。
pg_result_status() から返されます。 致命的なエラーが発生しました。
pg_transaction_status() から返されます。 接続は現在アイドル状態で、トランザクション内ではありません。
pg_transaction_status() から返されます。 接続内でコマンドを実行中です。クエリが接続を通じて送信され、 まだ完了していません。
pg_transaction_status() から返されます。 接続は現在アイドル状態で、トランザクションブロック内にあります。
pg_transaction_status() から返されます。 接続は現在アイドル状態で、トランザクション処理に失敗しています。
pg_transaction_status() から返されます。 接続が正常ではありません。
pg_result_error_field() に渡します。 深刻度です。その内容は ERROR、 FATAL、あるいは PANIC (エラーメッセージ内)、あるいは WARNING、 NOTICE、DEBUG、 INFO、あるいは LOG (通知メッセージ内)、あるいはこれらの各国語版のうちのどれかです。 常に存在します。
pg_result_error_field() に渡します。 エラーの SQLSTATE コードです。SQLSTATE コードは発生したエラーの種別を 特定します。これは、データベースエラーに対してフロントエンドの アプリケーションが適切な操作(エラー処理など)をできるようにするために 使用されます。このフィールドはローカライズされていません。また、 常に存在します。
pg_result_error_field() に渡します。 人間が判読できる最初のエラーメッセージ(たいてい 1 行)です。常に存在します。
pg_result_error_field() に渡します。 オプションの 2 番目のエラーメッセージで、問題に対する詳細な情報を 含みます。複数行にまたがることもあります。
pg_result_error_field() に渡します。 オプションのメッセージで、問題に対してどのように対応すべきかを指摘 します。エラーの詳細情報と違う点は、発生した事実ではなくアドバイス (時に不適切な場合もある)をするところです。複数行にまたがることも あります。
pg_result_error_field() に渡します。 エラーカーソルの位置を、もとのステートメント中の位置として表す 整数値を保持する文字列です。 最初の文字の位置は 1 で、それ以降(バイト数ではなく)文字数で 位置を数えます。
pg_result_error_field() に渡します。 PG_DIAG_STATEMENT_POSITION と同じ定義ですが、 こちらはカーソル位置が内部で生成されたコマンドを参照している場合に 使用されます。このフィールドが存在する場合は、常に PG_DIAG_INTERNAL_QUERY フィールドも存在します。
pg_result_error_field() に渡します。 失敗した内部生成コマンドのテキストです。例としては、PL/pgSQL 関数で 発行された SQL クエリなどがあてはまります。
pg_result_error_field() に渡します。 エラーが発生した状況を指定します。現在ここに含まれているのは、 アクティブなプロシージャの関数や内部生成クエリのコール履歴です。 これはエントリごとに 1 行のデータとなっており、直近のデータが 先頭にきます。
pg_result_error_field() に渡します。 エラーが報告された箇所の、PostgreSQL ソースコードでのファイル名です。
pg_result_error_field() に渡します。 エラーが報告された箇所の、PostgreSQL ソースコードでの行番号です。
pg_result_error_field() に渡します。 エラーが報告された箇所の、PostgreSQL ソースコードでの関数名です。
pg_set_error_verbosity() に渡します。 返されるメッセージを指定します。ここには深刻度・短い説明および 発生位置のみを含めます。通常は 1 行に収まるでしょう。
pg_set_error_verbosity() に渡します。 デフォルトで返されるメッセージで、上の内容に加えて詳細・ ヒントあるいは詳細情報を含めます(複数行にまたがるかもしれません)。
pg_set_error_verbosity() に渡します。 詳細モードでのメッセージで、有効なフィールドをすべて含めます。
pg_result_status() に渡します。 結果として数値が要求されていることを示します。
pg_result_status() に渡します。 結果としてテキストのコマンドタグが要求されていることを示します。
pg_convert() に渡します。 変換時に、テーブルのデフォルト値を無視します。
pg_convert() に渡します。 空文字列に対して、SQL の NULL を使用します。
pg_convert() に渡します。 NULL を SQL の NOT NULL に変換しないように します。
注意: すべての関数がすべての構築環境でサポートされるわけではありません。 サポートされる関数は、使用する libpq(PostgreSQL の C クライアント ライブラリ)のバージョンと libpq のコンパイル方法に依存します。 もし PHP の PostgreSQL 拡張モジュールに足りない関数がある場合、 その原因は libpq はその関数をサポートしていないことです。
注意: ほとんどの PostgreSQL 関数は、オプションの第 1 引数として connection を受け付けます。もしこれを 指定しなかった場合、直近にオープンされた接続を使用します。 そのような接続が存在しなかった場合、関数は FALSE を返します。
注意: PostgreSQL は、オブジェクトの生成時やクエリの実行時に 識別子(例: テーブル名・カラム名)を自動的に小文字に変換します。 この自動変換を防ぐには、識別子をダブルクォート("")でエスケープする 必要があります。
注意: PostgreSQL には、データベースのスキーマ情報(例: データベース内の すべてのテーブルなど)を取得するための特別なコマンドがありません。 その代わりに、PostgreSQL 7.4 以降では information_schema という標準スキーマが存在し、必要な情報が検索しやすい形式で格納されています。 詳しい情報は PostgreSQL ドキュメンテーション を参照ください。
この例では、PostgreSQL への接続・クエリの実行・結果の表示 そして切断の方法を説明します。