PostgreSQL 9.0.4文書 | ||||
---|---|---|---|---|
前のページ | 巻戻し | 第 31章libpq - C ライブラリ | 早送り | 次のページ |
よくあることですが、うまく分類できない関数がいくつか存在します。
PQfreemem
libpqが割り当てたメモリを解放します。
void PQfreemem(void *ptr);
特にPQescapeByteaConn
、PQescapeBytea
、PQunescapeBytea
およびPQnotifies
によりlibpqが割り当てたメモリーを解放します。
Microsoft Windowsにおいてfree()
ではなく、この関数を使用することが特に重要です。
DLLにおけるメモリ割り当てとアプリケーションにおけるその解放が、DLLとアプリケーションとでマルチスレッド/シングルスレッド、リリース用/デバッグ用、静的/動的フラグが同じ場合でのみ動作するためです。
Microsoft Windowsプラットフォーム以外では、この関数は標準ライブラリのfree()
関数と同じです。
PQconninfoFree
PQconndefaults
もしくはPQconninfoParse
が割り当てたデータ構造を解放します。
void PQconninfoFree(PQconninfoOption *connOptions);
単純なPQfreemem
は、配列が補助文字列への参照を含んでいることから、このためには作業しません。
PQencryptPassword
PostgreSQLパスワードの暗号化された形式を準備します。
char * PQencryptPassword(const char *passwd, const char *user);
この関数は、ALTER USER joe PASSWORD 'pwd'のようなコマンドを送信したいクライアントアプリケーションで使用されることを意図したものです。
こうしたコマンドでは、コマンドログが活動の監視などで晒されてしまうため、元々の平文テキストでパスワードを送信しないことが推奨されています。
その代わりに、この関数を使用して送信前にパスワードを暗号化形式に変換してください。
引数は平文のパスワードとそのSQL上のユーザ名です。
戻り値はmalloc
で割り当てられた文字列です。
メモリ不足の場合にNULLが返されます。
呼び出し元は、その文字列にエスケープしなければならない特殊な文字列が含まれていないことを仮定することができます。
処理が終わった時にPQfreemem
を使用して結果を解放してください。
PQmakeEmptyPGresult
与えられたステータスで空のPGresultオブジェクトを構築します。
PGresult *PQmakeEmptyPGresult(PGconn *conn, ExecStatusType status);
これは空のPGresultオブジェクトを割り当てて、初期化するlibpqの内部関数です。
メモリが割り当てられなかった場合、この関数はNULLを返します。
一部のアプリケーションで結果オブジェクト(特にエラーステータスを伴ったオブジェクト)それ自身を生成することが便利であることが分かりましたので、外部公開されました。
connが非ヌルで、statusがエラーを示唆している場合、特定された接続の現在のエラーメッセージはPGresultにコピーされます。
同時に、connが非ヌルの場合、接続で登録された任意のイベントプロシージャはPGresultにコピーされます。
(それらはPGEVT_RESULTCREATE呼び出しを受けませんが、PQfireResultCreateEvents
を理解します。)
libpq自身で返されたPGresultと同様に、最終的にはこのオブジェクトに対してPQclear
を呼び出さなければならないことに注意してください。
PQfireResultCreateEvents
PGresultオブジェクトに登録されたそれぞれのイベントプロシージャに対し、PGEVT_RESULTCREATEイベント(項31.12を参照)を発行します。 イベントプロシージャが成功の場合は非ゼロ、失敗の場合はゼロを返します。
int PQfireResultCreateEvents(PGconn *conn, PGresult *res);
conn引数はイベントプロシージャに渡されますが、直接には使用されません。 イベントプロシージャが使用しない場合はNULLです。
このオブジェクトに対し、PGEVT_RESULTCREATEもしくはPGEVT_RESULTCOPYイベントを過去に受け取ったイベントプロシージャは再び発行されません。
この関数がPQmakeEmptyPGResult
と分離されている主たる理由は、多くの場合イベントプロシージャを呼び出す前にPGresultを作成し、データを挿入するのが適切であることによります。
PQcopyResult
PGresultオブジェクトのコピーを作ります。
コピーは元の結果にいかなる方法でもリンクされず、コピーが不要になった時にPQclear
を呼び出されなければなりません。
関数が失敗するとNULLが返されます。
PGresult *PQcopyResult(const PGresult *src, int flags);
これは正確なコピーの作成を目的としたものではありません。 返された結果は常にPGRES_TUPLES_OK状態の中に置かれ、元の結果におけるエラーメッセージはまったくコピーされません。 (しかしコマンド状態文字列をコピーします。) flags引数はその他にコピーするものがないかを決定します。 それはいくつかのフラグのビット単位のORです。 PG_COPYRES_ATTRSは元の結果の属性(列定義)のコピーを指定します。 PG_COPYRES_TUPLESは元の結果のタプルのコピーを指定します。 (これは属性もコピーされることを意味しています。) PG_COPYRES_NOTICEHOOKSは元の結果の警告フックのコピーを指定します。 PG_COPYRES_EVENTSは元の結果イベントのコピーを指定します。 (しかし、元の結果に関連したインスタンスデータはまったくコピーされません。)
PQsetResultAttrs
PGresultオブジェクトの属性を設定します。
int PQsetResultAttrs(PGresult *res, int numAttributes, PGresAttDesc *attDescs);
提供されたattDescsは結果にコピーされます。 もしattDescsポインタがNULL、またはnumAttributesが1未満の場合、要求は無視され、関数は成功します。 resが既に属性を所有している場合、関数は失敗に終わります。 関数が失敗すると、戻り値はゼロです。 関数が成功すると戻り値は非ゼロになります。
PQsetvalue
PGresultオブジェクトのタプルフィールド値を設定します。
int PQsetvalue(PGresult *res, int tup_num, int field_num, char *value, int len);
必要に応じて関数は自動的に結果の内部タプル配列を肥大化させます。
しかし、tup_num引数はPQntuples
と同じか、もしくは小さくなければなりません。
その意味は、この関数は一回にタプル配列を1タプル大きくさせるだけだからです。
とは言っても、存在するいかなるタプルの任意のフィールドも、順序を問わず変更できます。
もしfield_numに値が既に存在すれば、書き換えられます。
lenが-1、またはvalueがNULLであれば、フィールドの値はSQLのNULLに設定されます。
valueは結果のプライベート格納領域にコピーされるため、関数が返った後ではもう必要がなくなります。
関数が失敗すると、戻り値はゼロです。
関数が成功すると戻り値は非ゼロになります。
PQresultAlloc
PGresultオブジェクトに補助ストレージを割り当てます。
void *PQresultAlloc(PGresult *res, size_t nBytes);
resが消去された時、この関数で割り付けられたメモリは解放されます。
関数が失敗すると戻り値はNULLです。
malloc
と同じように、どのような種類のデータでも結果は適切に整列されることが保証されています。