本節ではそれぞれのメッセージの詳細書式について説明します。 それぞれにはフロントエンド(F)、バックエンド(B)あるいは双方(F & B)から送出されることを示す印が付いています。 各メッセージには先頭にバイト数を持っていますが、バイト数を参照しなくてもメッセージの終わりを検知できるようにメッセージ書式は定義されています。 これは有効性検査を補助します。 (CopyDataメッセージはデータストリームの一部を形成しますので例外です。 個々のCopyDataメッセージの内容は自身でも解釈することができません。)
認証要求としてメッセージを識別します。
自身を含む、メッセージ内容の長さ(バイト単位)。
認証が成功したことを指定します。
メッセージを認証要求として識別します。
自身を含む、メッセージ内容の長さ(バイト単位)。
Kerberos V5認証が必要であることを指定します。
メッセージを認証要求として識別します。
自身を含む、メッセージ内容の長さ(バイト単位)。
平文パスワードが必要であることを指定します。
メッセージが認証要求であることを識別します。
自身を含む、メッセージ内容の長さ(バイト単位)。
MD5暗号化パスワードが必要であることを指定します。
パスワード暗号化用ソルトです。
メッセージが認証要求であることを識別します。
自身を含む、メッセージ内容の長さ(バイト単位)。
SCM資格証明メッセージが必要であることを指定します。
メッセージが認証要求であることを識別します。
自身を含む、メッセージ内容の長さ(バイト単位)。
GSSAPI認証証明メッセージが必要であることを指定します。
メッセージが認証要求であることを識別します。
自身を含む、メッセージ内容の長さ(バイト単位)。
SSPI認証証明メッセージが必要であることを指定します。
メッセージが認証要求であることを識別します。
自身を含む、メッセージ内容の長さ(バイト単位)。
このメッセージがGSSPAIまたはSSPIデータを含むことを指定します。
n
GSSAPIまたはSSPI認証データです。
メッセージが取消用キーデータであることを識別します。 もし、後でCancelRequestメッセージを発行する可能性があれば、フロントエンドはこの値を保存しなければなりません。
自身を含む、メッセージ内容の長さ(バイト単位)。
このバックエンドのプロセスID。
このバックエンドの秘密鍵。
このメッセージがBindコマンドであることを識別します。
自身を含む、メッセージ内容の長さ(バイト単位)。
宛先ポータルの名前です (空文字列で無名ポータルを選択します)。
元となるプリペアド文の名前です (空文字列で無名のプリペアド文を選択します)。
後続するパラメータ書式コードの数
(以下ではC
で表します)。
これは、パラメータが存在しない、あるいはすべてのパラメータがデフォルトの書式(テキスト)を使用することを示す0に、指定する書式コードをすべてのパラメータに適用することを示す1にすることができます。
さもなくば、これは実際のパラメータ数と同じになります。
C
]パラメータ書式コード。 現在、それぞれは0(テキスト)もしくは1(バイナリ)のいずれかでなければなりません。
後続するパラメータ値の数 (ゼロの場合もあります)。 これは問い合わせが必要とするパラメータ数と一致する必要があります。
次に、各パラメータに対して、以下のフィールドのペアが現れます。
パラメータ値のバイト単位の長さ(これには自身は含まれません)。 ゼロにすることもできます。 特別な場合として、-1はNULLというパラメータ値を示します。 NULLの場合、後続の値用のバイトはありません。
n
関連する書式コードで示される書式におけるパラメータの値。
n
は上述の長さです。
最後のパラメータの後に、以下のフィールドが現れます。
後続する結果列書式コードの数
(以下ではR
で表します)。
これは、結果列が存在しないことを示す0、あるいはすべての結果列が(もしあれば)デフォルトの書式コード(テキスト)を使用することを示す1にすることができます。
さもなくば、問い合わせの結果列の実際の数と同じになります。
R
]結果列の書式コード。 現在それぞれは0(テキスト)もしくは1(バイナリ)のいずれかでなければなりません。
メッセージがBind完了指示子であることを識別します。
自身を含む、メッセージ内容の長さ(バイト単位)。
自身を含む、メッセージ内容の長さ(バイト単位)。
取消要求コードです。
この値は、最上位16ビットに1234
が、下位16ビットに5678
を持つように選択されます。
(混乱を防ぐため、このコードはプロトコルバージョン番号と同一になってはいけません。)
対象バックエンドのプロセスIDです。
対象バックエンドの秘密鍵です。
メッセージがCloseコマンドであることを識別します。
自身を含む、メッセージ内容の長さ(バイト単位)。
プリペアド文を閉ざす時は'S
'。
ポータルを閉ざす時は'P
'です。
閉ざすプリペアド文またはポータルの名前です (空文字列で無名のプリペアド文または無名ポータルを選択します)。
メッセージがClose完了指示子であることを識別します。
自身を含む、メッセージ内容の長さ(バイト単位)。
メッセージがコマンド完了応答であることを識別します。
自身を含む、メッセージ内容の長さ(バイト単位)。
コマンドタグです。 これは通常どのSQLコマンドが完了したかを表す単一の単語です。
INSERT
コマンドの場合、タグはINSERT
です。
ここでoid
rows
rows
は挿入された行数です。
oid
は、rows
が1、かつ、対象テーブルがOIDを持つ場合、挿入された行のオブジェクトIDです。
さもなければ、oid
は0です。
DELETE
コマンドの場合、タグはDELETE
です。
ここでrows
rows
は削除された行数です。
UPDATE
コマンドの場合、タグはUPDATE
です。
ここでrows
rows
は更新された行数です。
SELECT
またはCREATE TABLE AS
の場合、タグはSELECT
となります。
ここでrows
rows
は取り込んだ行数です。
MOVE
コマンドの場合、タグはMOVE
です。
ここでrows
rows
は、カーソル位置が何行変更されたかを示す数です。
FETCH
コマンドの場合、タグはFETCH
です。
ここでrows
rows
は、カーソルから何行取り出したかを示す行数です。
COPY
コマンドの場合、タグはCOPY
です。
ここでrows
rows
は、コピーされた行数です(注意:この行数はPostgreSQL 8.2以降でのみ出力されます)。
メッセージがデータのCOPY
であることを識別します。
自身を含む、メッセージ内容の長さ(バイト単位)。
n
COPY
データストリームの一部を形成するデータです。
バックエンドから送信されるメッセージは、常に1つのデータ行に対応します。
しかし、フロントエンドから送信されるメッセージは任意のデータストリームに分割される可能性があります。
メッセージがCOPY
完了指示子であることを識別します。
自身を含む、メッセージ内容の長さ(バイト単位)。
メッセージがCOPY
失敗指示子であることを識別します。
自身を含む、メッセージ内容の長さ(バイト単位)。
失敗の原因を報告するエラーメッセージです。
メッセージがStart Copy Inの応答であることを識別します。 フロントエンドはここで必ずコピーインデータを送信しなければなりません (まだ準備ができていない場合はCopyFailメッセージを送信してください)。
自身を含む、メッセージ内容の長さ(バイト単位)。
0はCOPY
全体の書式がテキスト(行は改行で区切られ、列は区切り文字などで区切られます)であることを示します。
1は、コピー全体の書式がバイナリ(DataRowの書式と同様)であることを示します。
より詳細についてはCOPYを参照してください。
コピーされるデータ内の列数です
(以下ではN
と表されます)。
N
]各列で使用される書式コードです。 現在それぞれは0(テキスト)または1(バイナリ)でなければなりません。 コピー全体の書式がテキストの場合、すべてが0でなければなりません。
メッセージがStart Copy Outの応答であることを識別します。 このメッセージの後にコピーアウトデータが続きます。
自身を含む、メッセージ内容の長さ(バイト単位)。
0はCOPY
全体の書式がテキスト(行は改行で区切られ、列は区切り文字などで区切られます)であることを示します。
1はコピー全体の書式がバイナリ(DataRowの書式同様)であることを示します。
詳細についてはCOPYを参照してください。
コピーされるデータ内の列数です
(以下ではN
と表されます)。
N
]各列で使用される書式コードです。 現在それぞれは0(テキスト)または1(バイナリ)でなければなりません。 コピー全体の書式がテキストの場合、すべてが0でなければなりません。
メッセージがStart Copy Bothの応答であることを識別します。 このメッセージはストリーミングレプリケーションのみで使用されます。
自身を含む、メッセージ内容の長さ(バイト単位)。
0はCOPY
全体の書式がテキスト(行は改行で区切られ、列は区切り文字などで区切られます)であることを示します。
1はコピー全体の書式がバイナリ(DataRowの書式同様)であることを示します。
詳細についてはCOPYを参照してください。
コピーされるデータ内の列数です
(以下ではN
と表されます)。
N
]各列で使用される書式コードです。 現在それぞれは0(テキスト)または1(バイナリ)でなければなりません。 コピー全体の書式がテキストの場合、すべてが0でなければなりません。
メッセージがデータ行であることを識別します。
自身を含む、メッセージ内容の長さ(バイト単位)。
後に続く列値の数です (ゼロの場合もあります)。
次に、各列について以下のフィールドのペアが現れます。
列値のバイト単位の長さです (これには自身は含まれません)。 ゼロとすることもできます。 特別な場合として、-1はNULLという列値を示します。 NULLの場合、後続の値用のバイトはありません。
n
関連する書式コードで示される書式における列の値。
n
は上述の長さです。
メッセージがDescribeコマンドであることを識別します。
自身を含む、メッセージ内容の長さ(バイト単位)。
プリペアド文の記述の場合は'S
'。
ポータルの記述の場合は'P
'です。
記述を求めるプリペアド文またはポータルの名前です (空文字列で無名のプリペアド文または無名ポータルを選択します)。
メッセージが空の問い合わせ文字列に対する応答であることを識別します (これはCommandCompleteを置き換えます)。
自身を含む、メッセージ内容の長さ(バイト単位)。
メッセージがエラーであることを識別します。
自身を含む、メッセージ内容の長さ(バイト単位)。
このメッセージの本体には、ゼロバイトを終端として後続する、1つ以上の識別されるフィールドが含まれます。 フィールドは任意の順番で現れる可能性があります。 各フィールドには以下があります。
フィールド種類を識別するコードです。 ゼロならば、メッセージの終端であり、後続する文字列がないことを表します。 51.6. エラーおよび警報メッセージフィールドに、現時点でフィールド種類として定義されているものを列挙します。 将来もっと多くのフィールド種類が追加される可能性がありますので、フロントエンドは、認知できない種類のフィールドに対して何もせずに無視すべきです。
フィールド値です。
メッセージがExecuteコマンドであることを識別します。
自身を含む、メッセージ内容の長さ(バイト単位)。
実行するポータルの名前です。 (空文字列で無名ポータルを選択します)。
ポータルが行を返す問い合わせの場合、返される行数の最大値です (他の問い合わせでは無視されます)。 ゼロは「無制限」を表します。
メッセージがFlushコマンドであることを識別します。
自身を含む、メッセージ内容の長さ(バイト単位)。
メッセージが関数呼び出しであることを識別します。
自身を含む、メッセージ内容の長さ(バイト単位)。
呼び出す関数のオブジェクトIDを指定します。
後述する引数書式コード数です
(以下ではC
と表します)。
これは、引数が存在しない、あるいは、すべての引数がデフォルトの書式(テキスト)を使用することを示す0に、指定する書式コードをすべての引数に適用することを示す1にすることができます。
さもなくば、これは実際の引数の数と同じになります。
C
]引数の書式コードです。 それぞれは、0(テキスト)もしくは1(バイナリ)でなければなりません。
関数に提供する引数の数を指定します。
次に、各引数に対して以下のフィールドのペアが現れます。
引数の値のバイト単位の長さです (これには自身は含まれません)。 0とすることもできます。 特別な場合として、-1はNULLという引数の値を示します。 NULLの場合、後続の値用のバイトはありません。
n
関連する書式コードで示される書式における引数の値。
n
は上述の長さです。
最後の引数の後に、以下のフィールドが現れます。
関数結果用の書式コードです。 現在、0(テキスト)または1(バイナリ)でなければなりません。
メッセージが関数呼び出しの結果であることを識別します。
自身を含む、メッセージ内容の長さ(バイト単位)。
関数の結果の値のバイト単位の長さです (これには自身は含まれません)。 ゼロとすることもできます。 特別な場合として、-1はNULLという関数の結果の値を示します。 NULLの場合、後続の値用のバイトはありません。
n
関連する書式コードで示される書式における関数の結果の値。
n
は上述の長さです。
メッセージがデータなしの指示子であることを識別します。
自身を含む、メッセージ内容の長さ(バイト単位)。
メッセージが警報であることを識別します。
自身を含む、メッセージ内容の長さ(バイト単位)。
このメッセージの本体には、ゼロバイトを終端として後続する、1つ以上の識別されるフィールドが含まれます。 フィールドは任意の順番で現れる可能性があります。 各フィールドには以下があります。
フィールド種類を識別するコードです。 ゼロならば、メッセージの終端であり、後続する文字列がないことを表します。 51.6. エラーおよび警報メッセージフィールドに、現時点でフィールド種類として定義されているものを列挙します。 将来もっと多くのフィールド種類が追加される可能性がありますので、フロントエンドは、認知できない種類のフィールドに対して何もせずに無視すべきです。
フィールドの値です。
メッセージが通知応答であることを識別します。
自身を含む、メッセージ内容の長さ(バイト単位)。
通知元バックエンドのプロセスIDです。
通知の発生元となったチャネル名です。
通知プロセスから渡される「ペイロード」文字列です。
メッセージがパラメータ記述であることを識別します。
自身を含む、メッセージ内容の長さ(バイト単位)。
文で使用されるパラメータ数です (ゼロとすることができます)。
そして、各パラメータに対して、以下が続きます。
パラメータのデータ型のオブジェクトIDを指定します。
メッセージが実行時パラメータ状態報告であることを識別します。
自身を含む、メッセージ内容の長さ(バイト単位)。
報告される実行時パラメータの名前です。
そのパラメータの現在値です。
メッセージがParseコマンドであることを識別します。
自身を含む、メッセージ内容の長さ(バイト単位)。
宛先のプリペアド文の名前です (空文字列で無名のプリペアド文を選択します)。
解析される問い合わせ文字列です。
指定されるパラメータデータ型の数です (ゼロとすることができます)。 これは、問い合わせ文字列内にあるパラメータの数を示すものではないことに注意してください。 フロントエンドが型指定を希望するパラメータの数でしかありません。
その後、各パラメータに対し、以下が続きます。
パラメータのデータ型のオブジェクトIDを指定します。 ここにゼロを書くことは型指定を行わないことと同じです。
メッセージがParse完了指示子であることを識別します。
自身を含む、メッセージ内容の長さ(バイト単位)。
メッセージがパスワード応答であることを識別します。 これがGSSAPIまたはSSPI応答メッセージでも使用されることに注意してください。 (これは本当は設計エラーです。こうした場合含まれるデータはヌル終端の文字列ではなく、任意のバイナリデータを取り得るためです。)
自身を含む、メッセージ内容の長さ(バイト単位)。
パスワードです (必要ならば暗号化されています)。
メッセージがポータル中断指示子であることを識別します。 これは、Executeメッセージの行数制限に達した場合にのみ現れることに注意してください。
自身を含む、メッセージ内容の長さ(バイト単位)。
メッセージが簡易問い合わせであることを識別します。
自身を含む、メッセージ内容の長さ(バイト単位)。
問い合わせ文字列自体です。
このメッセージ種類を識別します。 バックエンドで新しい問い合わせサイクルの準備が整った時には常にReadyForQueryが送信されます。
自身を含む、メッセージ内容の長さ(バイト単位)。
現在のバックエンドのトランザクション状態指示子です。
取り得る値は、待機状態(トランザクションブロックにない状態)に'I
'、トランザクションブロック内の場合に'T
'、失敗したトランザクションブロック(ブロックが終わるまで問い合わせは拒絶されます)内の場合に'E
'です。
メッセージが行の記述であることを識別します。
自身を含む、メッセージ内容の長さ(バイト単位)。
行内のフィールド数を指定します (ゼロとすることができます)。
その後、各フィールドに対して以下が続きます。
フィールド名です。
フィールドが特定のテーブルの列として識別できる場合、テーブルのオブジェクトIDです。 さもなくばゼロです。
フィールドが特定のテーブルの列として識別できる場合、列の属性番号です。 さもなくばゼロです。
フィールドのデータ型のオブジェクトIDです。
データ型の大きさ(pg_type.typlen
を参照)です。
負の値が可変長の型を表すことに注意してください。
型修飾子(pg_attribute.atttypmod
を参照)です。
修飾子の意味は型に固有です。
フィールドに使用される書式コードです。 現在、0(テキスト)または1(バイナリ)のいずれかになります。 RowDescriptionがステートメント用のDescribeから返された場合、書式コードはまだ不明ですので、常に0になります。
自身を含む、メッセージ内容の長さ(バイト単位)。
SSL要求コードです。
この値は、最上位16ビットに1234
が、下位16ビットに5679
を持つように選択されます
(混乱を防ぐため、このコードはプロトコルバージョン番号と同一になってはいけません)。
自身を含む、メッセージ内容の長さ(バイト単位)。
プロトコルバージョン番号です。 最上位16ビットは主バージョン番号(本章で説明したプロトコルでは3)です。 下位16ビットは副バージョン番号(本章で説明したプロトコルでは0)です。
プロトコルバージョン番号の後に、1つ以上のパラメータ名と値文字列のペアが続きます。
最後の名前と値のペアの後に終端としてゼロバイトが必要です。
パラメータは任意の順番で現れることができます。
user
は必須です。
他は省略可能です。
各パラメータは以下のように指定されます。
パラメータ名です。 現在認識される名前を以下に示します。
user
接続するデータベースユーザ名です。 必須。 デフォルトはありません。
database
接続するデータベースです。 デフォルトはユーザ名です。
options
バックエンド用のコマンドライン引数です。
(これは廃棄予定であり、個々の実行時パラメータを設定する方が好ましいです。)
この文字列の中の空白は、バックスラッシュ(\
)でエスケープされていなければ、引数を分けるためのものとみなされます。
バックスラッシュそのものを表すためには\\
と書いてください。
上記に加え、バックエンドの起動時に設定可能な、任意の実行時パラメータが列挙される可能性があります。 こうした設定は、バックエンド起動時に(もしあればコマンドライン引数の解析の後に)適用されます。 この値はセッションのデフォルトとして動作します。
パラメータの値です。
メッセージがSyncコマンドであることを識別します。
自身を含む、メッセージ内容の長さ(バイト単位)。
メッセージが終了であることを識別します。
自身を含む、メッセージ内容の長さ(バイト単位)。