您好,登錄后才能下訂單哦!
在 PostgreSQL 中使用觸發(fā)器可以實(shí)現(xiàn)自動(dòng)維護(hù)歷史記錄的功能。具體步驟如下:
CREATE TABLE user_history (
id SERIAL PRIMARY KEY,
user_id INT,
name VARCHAR(50),
email VARCHAR(50),
action VARCHAR(10),
action_timestamp TIMESTAMP
);
CREATE OR REPLACE FUNCTION log_user_history()
RETURNS TRIGGER AS $$
BEGIN
IF TG_OP = 'INSERT' THEN
INSERT INTO user_history(user_id, name, email, action, action_timestamp)
VALUES (NEW.id, NEW.name, NEW.email, 'INSERT', NOW());
ELSIF TG_OP = 'UPDATE' THEN
INSERT INTO user_history(user_id, name, email, action, action_timestamp)
VALUES (NEW.id, NEW.name, NEW.email, 'UPDATE', NOW());
ELSIF TG_OP = 'DELETE' THEN
INSERT INTO user_history(user_id, name, email, action, action_timestamp)
VALUES (OLD.id, OLD.name, OLD.email, 'DELETE', NOW());
END IF;
RETURN NULL;
END;
$$ LANGUAGE plpgsql;
CREATE TRIGGER user_history_trigger
AFTER INSERT OR UPDATE OR DELETE ON users
FOR EACH ROW
EXECUTE FUNCTION log_user_history();
現(xiàn)在,當(dāng)對(duì)用戶表進(jìn)行插入、更新或刪除操作時(shí),觸發(fā)器會(huì)自動(dòng)將歷史記錄插入到歷史記錄表中,從而實(shí)現(xiàn)自動(dòng)維護(hù)歷史記錄的功能。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。