以下に、シンプルで簡単な方法とコード例を使用して、PostgreSQLの監査テーブルを実装する手順を説明します。
- 監査テーブルの作成: まず、新しいテーブルを作成して監査ログを保存するためのスキーマを定義します。例えば、"audit_log"という名前のテーブルを作成する場合、以下のコマンドを使用します。
CREATE TABLE audit_log (
id SERIAL PRIMARY KEY,
event_type VARCHAR(255),
event_timestamp TIMESTAMP,
event_data JSONB
);
上記のコマンドでは、ID、イベントのタイプ、イベントのタイムスタンプ、およびイベントのデータを保存するためのJSONBフィールドが含まれています。必要に応じてフィールドをカスタマイズしてください。
- トリガーの作成: 次に、トリガーを使用してデータベースの変更を監査テーブルに記録します。例えば、テーブルの更新操作を監査する場合、以下のようなトリガーを作成します。
CREATE OR REPLACE FUNCTION audit_table_trigger()
RETURNS TRIGGER AS $$
BEGIN
INSERT INTO audit_log (event_type, event_timestamp, event_data)
VALUES ('UPDATE', NOW(), row_to_json(NEW));
RETURN NEW;
END;
$$ LANGUAGE plpgsql;
CREATE TRIGGER audit_table_trigger
AFTER UPDATE ON your_table
FOR EACH ROW
EXECUTE FUNCTION audit_table_trigger();
- 監査ログの利用: 監査ログは、監査テーブルに保存されるため、必要な時にそれをクエリして使用できます。例えば、特定のイベントタイプのログを取得する場合、以下のようなクエリを使用します。
SELECT * FROM audit_log WHERE event_type = 'UPDATE';
上記のクエリでは、'UPDATE'というイベントタイプのログを取得しています。必要に応じてクエリをカスタマイズしてください。
以上が、PostgreSQLの監査テーブルの実装方法の概要です。これらの手順を参考にして、データベースの操作履歴を追跡するための監査機能を実装してみてください。