PostgreSQL中insert_username的擴(kuò)展使用
insert_username 是 PostgreSQL 的一個(gè)實(shí)用擴(kuò)展,用于自動(dòng)記錄數(shù)據(jù)行的創(chuàng)建者和最后修改者信息。這個(gè)擴(kuò)展特別適合需要審計(jì)跟蹤的應(yīng)用場景。
一 擴(kuò)展安裝與啟用
1.1 安裝擴(kuò)展
-- 使用超級用戶安裝 CREATE EXTENSION insert_username;
1.2 驗(yàn)證安裝
-- 查看已安裝擴(kuò)展 SELECT * FROM pg_available_extensions WHERE name = 'insert_username'; -- 查看擴(kuò)展提供的函數(shù) \df+ insert_username.*
輸出示例:
white=# CREATE EXTENSION insert_username;
CREATE EXTENSION
white=# SELECT * FROM pg_available_extensions WHERE name = 'insert_username';
name | default_version | installed_version | comment
-----------------+-----------------+-------------------+--------------------------------------------
insert_username | 1.0 | 1.0 | functions for tracking who changed a table
(1 row)
white=# \df+ insert_username.*
List of functions
Schema | Name | Result data type | Argument data types | Type | Volatility | Parallel | Owner | Security | Access privileges | Language | Internal name | D
escription
--------+------+------------------+---------------------+------+------------+----------+-------+----------+-------------------+----------+---------------+--
-----------
(0 rows)
white=#
二 基本功能與使用
2.1 核心功能
該擴(kuò)展提供兩個(gè)主要功能:
- 自動(dòng)插入當(dāng)前用戶名到指定列(記錄創(chuàng)建者)
- 自動(dòng)更新當(dāng)前用戶名到指定列(記錄最后修改者)
2.2 基本用法示例
-- 創(chuàng)建測試表
CREATE TABLE documents (
id serial PRIMARY KEY,
content text,
created_by text, -- 記錄創(chuàng)建者
modified_by text -- 記錄最后修改者
);
-- 為表添加觸發(fā)器
CREATE TRIGGER track_document_users
BEFORE INSERT OR UPDATE ON documents
FOR EACH ROW EXECUTE FUNCTION insert_username();
輸出示例:
white=# CREATE TABLE yewu1.documents (
white(# id int,
white(# name varchar(20),
white(# created_by text,
white(# modified_by text
white(# );
CREATE TABLE
white=# CREATE TRIGGER track_document_users
white-# BEFORE INSERT OR UPDATE ON yewu1.documents
white-# FOR EACH ROW EXECUTE FUNCTION insert_username();
CREATE TRIGGER
white=#
white=# \d yewu1.documents
Table "yewu1.documents"
Column | Type | Collation | Nullable | Default
-------------+-----------------------+-----------+----------+---------
id | integer | | |
name | character varying(20) | | |
created_by | text | | |
modified_by | text | | |
Triggers:
track_document_users BEFORE INSERT OR UPDATE ON yewu1.documents FOR EACH ROW EXECUTE FUNCTION insert_username()
三 高級配置選項(xiàng)
3.1 自定義列名
-- 創(chuàng)建使用不同列名的表
CREATE TABLE projects (
id serial PRIMARY KEY,
name text,
creator text, -- 替代 created_by
last_editor text -- 替代 modified_by
);
-- 使用參數(shù)指定列名
CREATE TRIGGER track_project_users
BEFORE INSERT OR UPDATE ON projects
FOR EACH ROW EXECUTE FUNCTION insert_username('creator', 'last_editor');
3.2 選擇性應(yīng)用
-- 只跟蹤創(chuàng)建者
CREATE TRIGGER track_creator_only
BEFORE INSERT ON projects
FOR EACH ROW EXECUTE FUNCTION insert_username('creator', NULL);
-- 只跟蹤修改者
CREATE TRIGGER track_editor_only
BEFORE UPDATE ON projects
FOR EACH ROW EXECUTE FUNCTION insert_username(NULL, 'last_editor');
四 擴(kuò)展內(nèi)部原理
4.1 實(shí)現(xiàn)機(jī)制
insert_username 擴(kuò)展實(shí)際上創(chuàng)建了一個(gè)觸發(fā)器函數(shù),該函數(shù):
- 在 INSERT 操作時(shí)設(shè)置
created_by列為當(dāng)前用戶名 - 在 UPDATE 操作時(shí)設(shè)置
modified_by列為當(dāng)前用戶名
4.2 使用的PostgreSQL特性
- 觸發(fā)器函數(shù)
current_user系統(tǒng)函數(shù)- 可變參數(shù)處理
五 性能考慮
5.1 性能影響
- 觸發(fā)器增加的開銷通常很小
- 每行操作增加少量CPU時(shí)間
- 不影響查詢性能,只影響DML操作
5.2 優(yōu)化建議
-- 對大表考慮禁用觸發(fā)器進(jìn)行批量操作 ALTER TABLE large_table DISABLE TRIGGER track_large_table_users; -- 批量更新操作 UPDATE large_table SET ...; -- 重新啟用觸發(fā)器 ALTER TABLE large_table ENABLE TRIGGER track_large_table_users;
六 與其他擴(kuò)展的對比
| 特性 | insert_username | temporal_tables | pg_audit |
|---|---|---|---|
| 用戶跟蹤 | ? | ? | ? |
| 時(shí)間跟蹤 | ? | ? | ? |
| 完整審計(jì) | ? | ? | ? |
| 使用復(fù)雜度 | 簡單 | 中等 | 復(fù)雜 |
| 性能影響 | 低 | 中 | 高 |
七 最佳實(shí)踐
命名一致性:在所有表中使用相同的列名(如created_by/modified_by)
組合使用:與時(shí)間戳觸發(fā)器結(jié)合使用
權(quán)限控制:
-- 防止手動(dòng)修改跟蹤列 REVOKE UPDATE ON created_by FROM public;
文檔記錄:在數(shù)據(jù)庫文檔中記錄審計(jì)策略
異常處理:考慮添加錯(cuò)誤處理邏輯
八 限制與注意事項(xiàng)
- 不記錄超級用戶的更改(如postgres用戶)
- 需要觸發(fā)器權(quán)限才能創(chuàng)建相關(guān)觸發(fā)器
- 不會(huì)跟蹤DELETE操作
- 在多語句事務(wù)中,用戶名是事務(wù)開始時(shí)的用戶
insert_username擴(kuò)展提供了輕量級、簡單易用的用戶變更跟蹤功能,非常適合基本的審計(jì)需求,但對于復(fù)雜的審計(jì)場景可能需要更全面的解決方案。
到此這篇關(guān)于PostgreSQL中insert_username的擴(kuò)展的文章就介紹到這了,更多相關(guān)PostgreSQL insert_username擴(kuò)展內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- 在PostgreSQL上安裝并使用擴(kuò)展模塊的教程
- postgresql 中的加密擴(kuò)展插件pgcrypto用法說明
- PHP實(shí)現(xiàn)基于PDO擴(kuò)展連接PostgreSQL對象關(guān)系數(shù)據(jù)庫示例
- PostgreSQL的dblink擴(kuò)展模塊使用
- PostgreSQL中pageinspect 的擴(kuò)展使用小結(jié)
- PostgreSQL的擴(kuò)展adminpack使用
- PostgreSQL的擴(kuò)展 dblink及安裝使用方法
- PostgreSQL的擴(kuò)展dict_int應(yīng)用案例解析
- PostgreSQL擴(kuò)展bloom的具體使用
相關(guān)文章
PostgreSQL定時(shí)清理舊數(shù)據(jù)的實(shí)現(xiàn)方法
最近覺得數(shù)據(jù)庫中每日數(shù)據(jù)不需要都保持,只需要保留30天的,所以這篇文章給大家介紹了PostgreSQL定時(shí)清理舊數(shù)據(jù)的實(shí)現(xiàn)方法,文中通過代碼示例和圖文給大家介紹的非常詳細(xì),具有一定的參考價(jià)值,需要的朋友可以參考下2024-03-03
PotgreSQL?基于時(shí)間點(diǎn)恢復(fù)過程
本篇文章介紹?PostgreSQL?基于時(shí)間點(diǎn)恢復(fù)(point-in-time-recover)需要的條件及恢復(fù)過程,屬于操作說明,對PotgreSQL?時(shí)間點(diǎn)恢復(fù)相關(guān)知識感興趣的朋友跟隨小編一起看看吧2023-08-08
PostgreSQL中insert_username的擴(kuò)展使用
insert_username?是 PostgreSQL 的一個(gè)實(shí)用擴(kuò)展,用于自動(dòng)記錄數(shù)據(jù)行的創(chuàng)建者和最后修改者信息,本文就來詳細(xì)的介紹一下insert_username擴(kuò)展,感興趣的可以了解一下2025-06-06
玩轉(zhuǎn)PostgreSQL之30個(gè)實(shí)用SQL語句
本文主要整理總結(jié)了30個(gè)實(shí)用SQL,方便大家可以高效利用PostgreSQL,需要的朋友可以參考下2022-11-11
PostgreSQL中查看當(dāng)前時(shí)間和日期的幾種常用方法
在 PostgreSQL 中,有多個(gè)函數(shù)可以用來查看當(dāng)前時(shí)間和日期,這些函數(shù)在處理時(shí)間戳、日期和時(shí)間的計(jì)算時(shí)非常有用,以下是幾種常用的查看當(dāng)前時(shí)間和日期的函數(shù)及示例,需要的朋友可以參考下2024-10-10
Postgresql根據(jù)響應(yīng)數(shù)據(jù)反向?qū)崿F(xiàn)建表語句與insert語句的過程
根據(jù)已有數(shù)據(jù),可構(gòu)建名為products的表,包含id(自增主鍵)、title(非空字符串)、progress(非空整數(shù))三個(gè)字段,建表后,可通過insert語句插入數(shù)據(jù),這種反向操作有助于從現(xiàn)有數(shù)據(jù)結(jié)構(gòu)出發(fā),快速構(gòu)建數(shù)據(jù)庫表,并進(jìn)行數(shù)據(jù)填充,感興趣的朋友跟隨小編一起看看吧2022-02-02
PostgreSQL連接數(shù)過多報(bào)錯(cuò):too many clients already的解決
在使用 Navicat 連接 PostgreSQL 數(shù)據(jù)庫時(shí),突然遭遇到了一個(gè)報(bào)錯(cuò):“FATAL: sorry, too many clients already”,這一錯(cuò)誤提示表明數(shù)據(jù)庫連接數(shù)已經(jīng)達(dá)到上限,無法再創(chuàng)建新連接,所以本文給大家介紹了相關(guān)的解決辦法,需要的朋友可以參考下2024-03-03
PostgreSQL 實(shí)現(xiàn)登錄及修改密碼操作
這篇文章主要介紹了PostgreSQL 實(shí)現(xiàn)登錄及修改密碼操作,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-01-01

