POSTGRESQL 通过TRIGGER 解决数据库表丢失数据的问题

news2025/2/21 21:49:10

26d0fc970dd95a9d41717a9bca74853c.png

开头还是介绍一下群,如果感兴趣polardb ,mongodb ,mysql ,postgresql ,redis 等有问题,有需求都可以加群群内有各大数据库行业大咖,CTO,可以解决你的问题。加群请联系 liuaustin3 ,在新加的朋友会分到2群(共790人左右 1 + 2)

最近遇到一个难题,关于POSTGRESQL 的Tigger问题,实际上我是十分不愿意在数据库中使用tigger, 管理的问题,性能的问题,以及可能在你不清晰你部署了tigger 的情况下,触发到底会发生什么的问题。但实际的问题中,还是会被逼无奈的使用TIGGER ,所以本期的说说TIGGER 我们怎么用。

我们先熟悉一下TRIGGER 的工作范围和触发场景,实际上在使用TRIGGER 上还是有一些门道的

1  before or after  这是一个针对事件触发次序的设置,触发分为,事前触发和事后触发,事前触发为在实际操作数据行或表时,需先对触发器的操作进行相应,相应后才能进行触发触发器的操作。

这个对于系统的性能消耗较大,但对于一些情况下是必须的,如你想捕捉触发某条删除操作的语句是什么那么你需要在操作DELETE的操作前,就对pg_stat_activity 的操作进行一个捕捉,而不是放到AFTER 操作,否则大概率你将一无所获。

而 after 相对于事务commit了,或在事务中的这个DML操作完成了,那么就可以触发这个操作了,相对于before ,after 会对于系统的性能消耗相对小一些,当然这也根据你的触发TIGGER 后的操作的工作有关。

1a14dfa0aed23e33c22d15a873152633.png

2  FOR  EACH ROW or  FOR EACH STATEMENT 

这个部分是第二个针对触发器性能影响的关键,FOR  EACH ROW 在触发后,会对于语句操作的每一行都进行触发器的操作,这样的性能消耗要大,而反过来如果使用FOR EACH STATEMENT 的操作,将对于系统的影响相对小,语句只触发一次触发器的操作。

所以在建立TRIGGER 时,正确选择是for each row , or  for each statement 是重要的。

e98c3a877c69e7f6fb601a1fcd0a9735.png

同时需要注意的是在表上建立的约束,也是属于触发器,约束也是after row 类型的触发器。

下面我们建立一个关于删除表中数据时就触发对于当前数据库运行时的语句进行snapshot的trigger.

SELECT 

    tgname as "Trigger Name",

    tgenabled as "Status",

    tgisinternal as "Is Internal",

    proname as "Function Name",

    n.nspname as "Schema",

    pg_get_triggerdef(t.oid) as "Trigger Definition"

FROM     pg_trigger t

JOIN     pg_class c ON t.tgrelid = c.oid

JOIN     pg_namespace n ON c.relnamespace = n.oid

JOIN     pg_proc p ON t.tgfoid = p.oid

where  tgisinternal = 'f';

29831777ff0a8202e34c46ee6345a2ba.png

SELECT proname, pg_get_function_arguments(oid) as args, pg_get_function_result(oid) as result_type,pg_get_functiondef(oid) as "Source Code"FROM pg_catalog.pg_proc

WHERE pronamespace = (SELECT oid FROM pg_namespace WHERE nspname = 'public') and proname like 'delete%';

通过定义函数,并且将函数在trigger 中进行调用,这里需要说明如果是trigger 调用的函数如何去写。

5fe6beb76bc1ec5e4eb46350318d72b8.png

上图为尝试对这个表进行delete 操作或truncate  操作等等,我们均可以通过触发器进行后续操作的记录session的表进行,可以发现操作的语句。

目前看这个方案是可以捕捉到对于特定表进行delete ,truncate 触发记录的工作。

这里需要注意的是触发器函数,虽然都是函数,但是在使用触发器时是需要定义触发器函数的。首先在trigger 中使用的函数是不需要返回参数的,

所以在函数中的return 返回的变量是特殊的指定的

NEW

  • 数据类型是RECORD;该变量为行级触发器中的INSERT/UPDATE操作保持新数据行。在语句级别的触发器以及DELETE操作,这个变量是null。

    OLD

  • 数据类型是RECORD;该变量为行级触发器中的UPDATE/DELETE操作保持新数据行。在语句级别的触发器以及INSERT操作,这个变量是null。

    所以这里我们选择的return 是 NEW  ,这里还有一个问题是采用的触发方式是before ,before 引发的触发操作,可以返回空,来让触发器跳过对于剩下行的操作,在DELETE中的常用方法是返回OLD.

说到这里,可能还有同学不明白 NEW 和 OLD 的用法,我们用下面的一个例子来讲明白,在什么时间用NEW 在什么时间用OLD

CREATE TRIGGER insert_user_trigger

BEFORE INSERT ON users

FOR EACH ROW

EXECUTE FUNCTION set_created_at();

CREATE OR REPLACE FUNCTION set_created_at()

RETURNS TRIGGER AS $$

BEGIN

    NEW.created_at = NOW();

    RETURN NEW;

END;

$$ LANGUAGE plpgsql;

上面的这个例子的意思是,建立一个插入数据的trigger ,在插入数据的时候,针对这一行数据的字段  created_at  插入时间

所以这里使用了 new 的方式来进行相关引用插入的新行,所以以这个例子为目标,则如果是删除数据,则一般是适应old ,对原有的行进行一些处理,或根本不处理等。

db891f611a8a8c80ea8aab4c2a17007e.png

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/539110.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Consul系列:什么是Consul?

引言 Consul 是 HashiCorp 公司推出的开源工具,用于实现分布式系统的服务发现与配置。与其他分布式服务注册与发现的方案, consu1 的方案更“一站式”,内置了服务注册 与发现框架、分布一致性协议实现、健康检查、Key/Value 存储、多数据中心…

多区域综合能源系统热网建模及系统运行优化(Matlab代码实现)

💥💥💞💞欢迎来到本博客❤️❤️💥💥 🏆博主优势:🌞🌞🌞博客内容尽量做到思维缜密,逻辑清晰,为了方便读者。 ⛳️座右铭&a…

(转载)从0开始学matlab(第4天)—子数组

你可以选择和使用一个 MATLAB 函数的子集,好像他们是独立的数组一样。在数组名后面加括号,括号里面是所有要选择的元素的下标,这样就能选择这个函数的子集了。例如,假设定义了一个数组 arr1 如下 arr1[1.1 -2.2 3.3 -4.4 5.5] 那…

EMI超标问题排查

基于场外EMC测试反馈,EMI测试超标,测试结果如下图; 通过图形我们 可以看出,主要EMI超标频率集中在1GHz(大约700M的时候最差)附近。 使用RS频谱仪结合近场探头,进行复测: 复测情况确实存在EMI问题集中在700MHz左右。 去掉时钟输出接口时; 效果明显 通过试验,可以得出…

Java进阶-文件操作

1.File类 1.1File类概述和构造方法 File类介绍 它是文件和目录路径名的抽象表示文件和目录是可以通过File封装成对象的对于File而言,其封装的并不是一个真正存在的文件,仅仅是一个路径名而已.它可以是存在的,也可以是不存在的.将来是要通过具体的操作把这个路径的内容转换为具…

6.Redis事务

6.Redis事务 是什么:Redis事务VS数据库事务怎么玩Errors inside a transactionWatch监控:Optimistic locking using check-and-set 是什么: Redis Transactions allow the execution of a group of commands in a single step, they are cen…

系列二、Vue脚手架的基本语法

一、基于3.x版本脚手架创建vue项目的方式 1.1、基于交互式命令行的方式,创建vue项目 vue create project-name 1.2、基于图形化界面的方式,创建vue项目 vue ui 1.2.1、创建新项目 -详情 1.2.2、创建新项目-预设 1.2.3、创建新项目-功能 1.2.4、创建新…

千万不要告诉别人自己的绩效!某面试官觉得求职者表现不错,找熟人打听他离职原因,听说因为绩效低被劝退,决定不要他了!...

自己的绩效可以告诉别人吗? 一位网友提示: 告诉别人自己的绩效很恐怖!在电梯里听到面试官说某求职者表现还不错,找熟人问了一下他上家公司的离职原因,听说是因为绩效低被劝退,所以不准备要他了。 网友说&am…

要不要和我们一起看看音视频技术未来的模样?

▲扫描图中二维码或点击“阅读原文” ▲ 直通LiveVideoStackCon 2023上海站九折优惠 2023年5月11日,Google I/O年度开发者大会完美落幕。随着PaLM2模型发布、Bard的自由访问,技术彻底迎来了“AI 时代”。 但今天我们想聊的并不是AI,而是一直支…

运用多输入模型优化不同维度特征

运用多输入模型优化不同维度特征 背景介绍 使用神经网络模型做用户付费金额预测,一种常见的特征工程场景,是把某个特定付费区间,比如付费金额大于10小于等于12的付费用户信息处理成特征,既可以将这部分用户的付费人数作为特征&a…

自助迁移工具升级!如何从 Confluence 切换至 ONES Wiki?

近日,ONES 升级了 Confluence 自助迁移工具,对迁移数据类型、迁移范围、迁移模式等多个维度的能力进行了提升,帮助企业更高效率、更低成本地将 Confluence 中的数据完整、准确地迁移至 ONES Wiki 中。 在 Confluence 与 ONES 服务资源充足的前…

国民游戏王者荣耀的真实地图开发之路

👉腾小云导读 相信很多人都玩过王者荣耀,大家在欣赏其华丽的游戏界面以及炫酷的游戏技能时,是否好奇过王者荣耀的地图是怎样开发出来的?在开发的历程中,都有哪些问题?是怎样解决的?本文将从其地…

飞桨+文心一言的“动力装置”,藏着百度财报的增长密码

我们习以为常的科技世界,正在以肉眼可见的速度被大模型所改变甚至重构。不想错失机遇的科技企业,都怀揣着造AI重器的梦想,各种大模型纷至沓来。 发布大模型只是开始,如同火箭发射,升空是第一步,后续能否顺利…

【运维知识进阶篇】集群架构-Nginx反向代理详解

在互联网请求中,客户端通常无法直接向服务端发起请求,就需要用代理服务,来实现客户端和的交互,起到一个中介的作用。 Nginx代理服务常见模式 Nginx代理按照应用场景模式可以分为正向代理和反向代理。 正向代理是内部上网过程中&a…

将矩阵按指定对角线转化为一个下三角矩阵numpy.tril()方法

【小白从小学Python、C、Java】 【计算机等考500强证书考研】 【Python-数据分析】 将矩阵按指定对角线转化为一个下三角矩阵 numpy.tril() 选择题 关于以下代码说法错误的一项是? import numpy as np a np.array([[1,2],[3,4]]) print("【显示】a\n",a) print(&…

Nevron Open Vision for .NET 2023.1 Crack

Nevron Open Vision for .NET 2023.1 添加对 .NET Core 7.0 的支持以及用于图表控件的新 3D 渲染引擎。 2023 年 5 月 17 日 - 14:09 新版本 特征 一般改进 添加了对 Microsoft .NET 7.0 的支持- NOV 现在完全支持 .NET Core 7.0,此外还支持 Microsoft .NET Framewo…

chatgpt赋能Python-pycharm降低numpy版本

Pycharm中降低Numpy版本的步骤 如果你在使用Pycharm进行Python编程时遇到了Numpy版本不兼容的问题,你可能需要降低Numpy的版本。在这篇文章中,我们将介绍如何在Pycharm中降低Numpy版本,以便Python程序能够正常运行。 什么是Numpy&#xff1…

测试入门篇

软件测试入门 1.啥是软件测试?2.测试和开发的区别3.测试和调试的区别4.软件测试人员需具备的素质5.测试入门5.1 需求介绍/从测试人员的角度看需求5.2 测试用例5.3 bug介绍5.4 软件的生命周期 6.开发模型6.1 瀑布模型6.2 螺旋模型6.3 增量、迭代模型6.4 敏捷模型(scr…

【贪吃蛇小游戏】宝塔面板快速搭建贪吃蛇小游戏Web网站 - 无需云服务器

文章目录 前言视频教程1. 环境安装2. 安装cpolar内网穿透3. 内网穿透4. 固定http地址5. 配置二级子域名6. 创建一个测试页面 转载自远程内网穿透的文章:Linux使用宝塔面板搭建网站,并内网穿透实现公网访问 前言 宝塔面板作为简单好用的服务器运维管理面…

【深度学习】Yolov8追踪从0到1, 这要是做计数啥的,简单的一批

文章目录 前言用了将近2年的yolov5了,之前主要做目标检测后面,还做了yolov5的分割任务和模型转换,现在又有了新任务了。是时间玩玩新模型了。 最好的方式是看文档:https://docs.ultralytics.com/ ![在这里插入图片描述](https://i…