SPI_prepare
により準備された計画に必要とされる引数の数を返す
SPI_prepare
で準備された計画で指定される引数のデータ型のOIDを返す
SPI_prepare
で準備された計画がSPI_cursor_open
で使用できる場合にtrueを返す
SPI_prepare
で準備された計画を実行するSPI_prepare
で作成された計画を使用したカーソルを設定するSPI_execute
や類似の関数によって生成された行セットを解放するサーバプログラミングインタフェース(SPI)は、ユーザ定義のC関数からSQL問い合わせを実行する機能をユーザに提供します。 SPIはパーサ、プランナ、オプティマイザ、エクゼキュータへのアクセスを単純化したインタフェース関数の集合です。 また、SPIは多少のメモリ管理を行います。
注意: 利用可能な手続き言語は、プロシージャからSQLコマンドを実行するための各種手段を提供します。 これらのほとんどは、SPIを元にしていますので、この文書はこれらの言語のユーザにとっても有用な場合があります。
誤解を防ぐために、これ以降、"関数"をSPIインタフェース関数の意味で、"プロシージャ"をSPIを呼び出すユーザ定義のC関数の意味で使うことにします。
コマンドがSPIの失敗を起こした場合、その制御はプロシージャには戻らないことに注意してください。 それどころか、プロシージャを実行していたトランザクションもしくは副トランザクションはロールバックされます (これはSPI関数のほとんどでエラーを返す規約があることから奇妙に思われるかもしれません。 しかし、こうした規約はSPI関数自身でエラーを検知した時にのみ適用されるものです)。 失敗する可能性があるSPI呼び出しを囲む副トランザクションを独自に用意することで、エラーの後の制御を戻すことができます。 要求される機構がまだ流動的であるため、これはまだ文書化されていません。
SPI関数は成功時に非負の結果を(戻り値、もしくは後述のSPI_resultグローバル変数の中に)返します。 エラー時、負の結果もしくはNULLを返します。
SPIを使用するソースコードファイルではexecutor/spi.hヘッダファイルをincludeしなければなりません。