このカテゴリーではPostgreSQLに関する記事をまとめています。

PostgreSQLでテーブルやカラムのコメントをSQLで取得する方法
PostgreSQLのテーブルコメントやカラムコメントをSQLで取得するにはPostgreSQLカタログの「pg_description」テーブルを参照します。

PostgreSQLでテーブルやカラムにコメントを設定する方法
PostgreSQLでテーブルやカラムにSQLでコメントを設定するには「COMMENT」コマンドを利用します。どちらの場合もコメントを削除する場合は設定する値にNULLを設定することで削除することができます。

PostgreSQLのDBlinkを使用して他のデータベースのテーブルを参照する方法
PostgreSQLのDBlinkを使用するにはextensionを導入し、dblinkでリモートデータベースへの接続を作成することで、リモートデータベースのテーブルにアクセスできるようになります。

PostgreSQLでINSERTとUPDATEを1行で実行するMERGE(UPSERT)を行う
PostgreSQLでは SQLServerのMERGE 文と同じことを行うにはCONFLICTを使って行います。

PostgreSQLで一時テーブルを作成する方法
PostgreSQLの一時テーブルは作成してからセッションが有効な間だけアクセスできるテーブルです。一時テーブルはセッション内のみ有効なので、セッションが切断された時には自動でテーブルが削除されるので、不要なテーブルが残ってしまうこともありません。また、他のセッションからも見れないので、同じ一時テーブル名が存在しても、セッションが異なればエラーにならず、それぞれの処理で同じテーブル名が使えることになります。

PostgreSQLでテーブルのプライマリキー(主キー)を削除する方法
PostgreSQLでテーブルのプライマリキーを削除するにはALTER TABLE 文を使います。通常のDROP INDEX文ではありません。

PostgreSQLのViewが更新可能かどうかチェックする方法
PostgreSQLのVIEW は一定の条件を満たせば、通常のテーブルと同様にVIEWの元テーブルに対してデータの挿入や更新が可能になります。挿入や更新が可能かどうかはinformation_schema.viewsを参照すれば判定することが可能です。

PostgreSQLで関数の定義(ソース)を取得する方法
PostgreSQLで関数の定義(ソース)を取得するSQLはpg_get_functiondef関数を利用すればできます。ただし、取得するためにはその関数のOIDが必要です。

PostgreSQLでトリガーの有効/無効を切り替える方法
PostgreSQLでテーブルに設定されているトリガーを有効にしたり無効にしたりするにはALTER TABLE文を使ってENABLE TRIGGER(有効)、DISABLE TRIGGER(無効)で切り替えることができます。

PostgreSQLでシーケンスの一覧を取得する方法
PostgreSQLでシーケンスの一覧を SQLで取得するにはpg_sequences、pg_classを利用すれば、スキマー名やその設定内容が取得できます。

PostgreSQLでVIEWの一覧を取得するSQL
PostgreSQLでVIEWの一覧を取得するには pg_views を利用することで一覧を取得することができます。

PostgreSQLでトリガーの一覧を取得する
PostgreSQLにはテーブルに対してデータを挿入(INSERT)の前後、更新(UPDATE)の前後、削除(DELETE)の前後のタイミングで自動で起動される処理をトリガーとして定義することができ、トリガーの情報はinformation_schema.triggersとpg_triggerを利用して取得します。

PostgreSQLにはISNULLやNVLがないので関数で自作する
PostgreSQLにはSQLServerのISNULLやOracleのNVL に対応する関数がないので値がNULLの場合に別の値に変換して取得するにはCOALESCEで代用します。今回は「多様型」の引数と戻り値を使ってISNULL関数を作成します。

PostgreSQLでプライマリキー、ユニークインデックス、インデックスを取得する方法
PostgreSQLでテーブルに設定されているプライマリキー、ユニークインデックス、インデックスを取得するにはpg_indexスキーマのindisprimary カラムとindisunique カラムを参照してそれぞれ取得します。

PostgreSQLで関数の一覧を取得する
PostgreSQLでSQLを使ってスト関数の一覧を取得するにはinformation_schema.routines,pg_procスキーマーを参照して取得します。取得したいオーナー名やユーザー名を指定して実行すると、より絞り込んだ関数の一覧を取得することができます。

PostgreSQLで接続しているデータベース名を取得する方法
PostgreSQLでアプリケーションが現在接続しているデータベース名を取得するにはcurrent_database()を使って取得します。

PostgreSQLでストアドプロシジャの一覧を取得する
PostgreSQLでSQLを使ってストアドプロシジャの一覧を取得するにはinformation_schema.routines,pg_procスキーマーを参照して取得します。取得したいオーナー名やユーザー名を指定して実行すると、より絞り込んだストアドプロシジャの一覧を取得することができます。

PostgreSQLでテーブルのカラム名・属性を取得する方法
PostgreSQLでテーブルのカラム名・属性情報の一覧はシステムカタログのinformation_schema.columnsを検索することで取得することができます。

PostgreSQLでデータベースの一覧を取得する方法
PostgreSQLで作成されているデータベースの一覧を取得するにはシステムカタログのpg_databaseを使用します。

PostgreSQLでテーブルの一覧を取得する方法
PostgreSQLでデータベース内に作成されているテーブルの一覧を取得するにはシステムカタログのpg_tablesを使用します。

PostgreSQLへ他の端末から接続する方法
他のコンピュータで稼働している PostgreSQL へはデフォルトでは許可されていません。接続するには設定を変更して再起動する必要があります。