V. サーバプログラミング

ここでは、ユーザ定義の関数、データ型、演算子、トリガなどを使用してサーバの機能を拡張する方法について説明します。 これらはおそらく、PostgreSQLに関するユーザ向けの文書を理解した後にのみたどり着く先進的な話題です。 また、最後の数章でPostgreSQLに附属するサーバサイドのプログラミング言語についても説明します。 同時にサーバサイドのプログラミング言語に関する一般的な問題についても説明します。 サーバサイドのプログラミング言語の章に進む前に、少なくとも、第33章(関数も説明しています)の最初の数節を読破することは重要です。

目次
33章SQLの拡張
33.1. 拡張の作用法
33.2. PostgreSQLの型システム
33.3. ユーザ定義関数
33.4. 問い合わせ言語(SQL)関数
33.5. 関数のオーバーロード
33.6. 関数の変動性分類
33.7. 手続き型言語関数
33.8. 内部関数
33.9. C言語関数
33.10. ユーザ定義の集約
33.11. ユーザ定義の型
33.12. ユーザ定義の演算子
33.13. 演算子最適化に関する情報
33.14. インデックス拡張機能へのインタフェース
34章トリガ
34.1. トリガ動作の概要
34.2. データ変更の可視性
34.3. Cによるトリガ関数の作成
34.4. 完全な例
35章ルールシステム
35.1. 問い合わせツリーとは
35.2. ビューとルールシステム
35.3. INSERTUPDATEDELETEについてのルール
35.4. ルールと権限
35.5. ルールおよびコマンドの状態
35.6. ルール対トリガ
36章手続き言語
36.1. 手続き言語のインストール
37章PL/pgSQL - SQL手続き言語
37.1. 概要
37.2. PL/pgSQLによる開発向けのヒント
37.3. PL/pgSQLの構造
37.4. 宣言
37.5.
37.6. 基本的な文
37.7. 制御構造
37.8. カーソル
37.9. エラーとメッセージ
37.10. トリガプロシージャ
37.11. Oracle PL/SQLからの移植
38章PL/Tcl - Tcl手続き型言語
38.1. 概要
38.2. PL/Tcl関数と引数
38.3. PL/Tclにおけるデータの値
38.4. PL/Tclにおけるグローバルデータ
38.5. PL/Tclからのデータベースアクセス
38.6. PL/Tclのトリガプロシージャ
38.7. モジュールとunknownコマンド
38.8. Tclプロシージャ名
39章PL/Perl - Perl手続き言語
39.1. PL/Perl関数と引数
39.2. PL/Perlからのデータベースアクセス
39.3. PL/Perlにおけるデータ値
39.4. PL/Perlにおけるグローバル変数
39.5. 信頼されたPL/Perlおよび信頼されないPL/Perl
39.6. PL/Perlトリガ
39.7. 制限および存在しない機能
40章PL/Python - Python手続き言語
40.1. PL/Python関数
40.2. トリガ関数
40.3. データベースアクセス
41章サーバプログラミングインタフェース
41.1. インタフェース関数
41.2. インタフェースサポート関数
41.3. メモリ管理
41.4. データ変更の可視性
41.5.