PostgreSql创建触发器并增加IF判断条件

在这里插入图片描述

在 PostgreSQL 中,可以使用触发器(Trigger)来在表上定义自定义的插入(INSERT)、更新(UPDATE)和删除(DELETE)操作的行为。触发器是与表相关联的特殊函数,它们在指定的操作发生时自动执行。

PostgreSQL创建触发器的语法

创建触发器
CREATE TRIGGER trigger_name
{BEFORE | AFTER} {INSERT | UPDATE | DELETE} ON table_name
[FOR EACH ROW]
[WHEN (condition)]
EXECUTE FUNCTION function_name();
  • trigger_name:触发器的名称。
  • BEFOREAFTER:指定触发器在操作之前或之后执行。
  • INSERTUPDATEDELETE:指定触发器与哪种操作相关联。
  • table_name:触发器所属的表名。
  • FOR EACH ROW:指定触发器为每一行执行。
  • WHEN (condition):可选项,指定触发器执行的条件。
  • EXECUTE FUNCTION function_name():指定触发器执行的函数。
创建触发器函数
CREATE FUNCTION function_name()
RETURNS TRIGGER AS $$
BEGIN-- 触发器的逻辑代码RETURN NEW; -- RETURN OLD; 或 RETURN NULL;
END;
$$ LANGUAGE plpgsql;
  • function_name:触发器函数的名称。
  • RETURNS TRIGGER:指定函数返回一个触发器对象。
  • $$ 是一种用于定义多行字符串的语法,用于将函数体中的代码块括起来,以便将多行代码作为一个字符串传递给 CREATE FUNCTION 语句。
  • BEGINEND:定义函数的代码块。
  • RETURN NEW;:在 BEFORE INSERTBEFORE UPDATE 触发器中,返回 NEW 表示修改后的行数据。
  • RETURN OLD;:在 AFTER UPDATEAFTER DELETEE 触发器中,返回 OLD 表示修改前的行数据。
  • RETURN NULL;:在 AFTER INSERTAFTER DELETE 触发器中,返回 NULL
删除触发器
DROP TRIGGER trigger_name ON table_name;
  • trigger_name:要删除的触发器的名称。
  • table_name:触发器所属的表名。

PostgreSQL创建触发器的案例

创建一张学生表
CREATE TABLE "public"."student" ("student_id" int4 NOT NULL DEFAULT nextval('student_student_id_seq'::regclass),"name" varchar(50) COLLATE "pg_catalog"."default" NOT NULL,"age" int4 NOT NULL,"gender" varchar(10) COLLATE "pg_catalog"."default" NOT NULL,"address" varchar(100) COLLATE "pg_catalog"."default" NOT NULL,"phone" varchar(20) COLLATE "pg_catalog"."default" NOT NULL,"grade" varchar(20) COLLATE "pg_catalog"."default" NOT NULL,CONSTRAINT "student_pkey" PRIMARY KEY ("student_id")
);ALTER TABLE "public"."student" OWNER TO "postgres";
COMMENT ON COLUMN "public"."student"."student_id" IS '学生id';
COMMENT ON COLUMN "public"."student"."name" IS '姓名';
COMMENT ON COLUMN "public"."student"."age" IS '年龄';
COMMENT ON COLUMN "public"."student"."gender" IS '性别';
COMMENT ON COLUMN "public"."student"."address" IS '地址';
COMMENT ON COLUMN "public"."student"."phone" IS '电话';
COMMENT ON COLUMN "public"."student"."grade" IS '年级';
创建触发器要求

student表地址addressBeijing的学生,写入到一张新的student_beijing表中,同步新增修改和删除。

CREATE TABLE "public"."student_beijing" ("student_id" int4 NOT NULL DEFAULT nextval('student_student_id_seq'::regclass),"name" varchar(50) COLLATE "pg_catalog"."default" NOT NULL,"age" int4 NOT NULL,"gender" varchar(10) COLLATE "pg_catalog"."default" NOT NULL,"address" varchar(100) COLLATE "pg_catalog"."default" NOT NULL,"phone" varchar(20) COLLATE "pg_catalog"."default" NOT NULL,"grade" varchar(20) COLLATE "pg_catalog"."default" NOT NULL,CONSTRAINT "student_beijing_pkey" PRIMARY KEY ("student_id")
);ALTER TABLE "public"."student_beijing" OWNER TO "postgres";
COMMENT ON COLUMN "public"."student_beijing"."student_id" IS '学生id';
COMMENT ON COLUMN "public"."student_beijing"."name" IS '姓名';
COMMENT ON COLUMN "public"."student_beijing"."age" IS '年龄';
COMMENT ON COLUMN "public"."student_beijing"."gender" IS '性别';
COMMENT ON COLUMN "public"."student_beijing"."address" IS '地址';
COMMENT ON COLUMN "public"."student_beijing"."phone" IS '电话';
COMMENT ON COLUMN "public"."student_beijing"."grade" IS '年级';
创建新增触发器
# 创建触发器函数
CREATE OR REPLACE FUNCTION student_insert_function() RETURNS TRIGGER AS $student_table$  BEGIN IF 'Beijing' = new.address THENINSERT INTO student_beijing (student_id,name,age,gender,address,phone,grade) VALUES (new.student_id,new.name,new.age,new.gender,new.address,new.phone,new.grade);END IF;RETURN NEW;   END;  
$student_table$ LANGUAGE plpgsql;# 创建新增触发器
CREATE TRIGGER student_insert_trigger AFTER INSERT ON student  
FOR EACH ROW EXECUTE PROCEDURE student_insert_function();# 删除触发器
DROP TRIGGER IF EXISTS student_insert_trigger ON student;
# 删除函数
DROP FUNCTION student_insert_function();
创建修改触发器
# 创建触发器函数
CREATE OR REPLACE FUNCTION student_update_function() RETURNS TRIGGER AS $student_table$  BEGIN IF 'Beijing' = new.address THENUPDATE student_beijing SET name = new.name,age = new.age,gender = new.gender,address = new.address,phone = new.phone,grade = new.grade WHERE student_id = old.student_id;END IF;RETURN NEW;   END;  
$student_table$ LANGUAGE plpgsql;# 创建修改触发器
CREATE TRIGGER student_update_trigger AFTER UPDATE ON student  
FOR EACH ROW EXECUTE PROCEDURE student_update_function();# 删除触发器
DROP TRIGGER IF EXISTS student_update_trigger ON student;
# 删除函数
DROP FUNCTION student_update_function();
创建删除触发器
# 创建触发器函数
CREATE OR REPLACE FUNCTION student_delete_function() RETURNS TRIGGER AS $student_table$  BEGIN IF 'Beijing' = old.address THENDELETE FROM student_beijing WHERE student_id = old.student_id;END IF;RETURN OLD;   END;  
$student_table$ LANGUAGE plpgsql;# 创建删除触发器
CREATE TRIGGER student_delete_trigger AFTER DELETE ON student  
FOR EACH ROW EXECUTE PROCEDURE student_delete_function();# 删除触发器
DROP TRIGGER IF EXISTS student_delete_trigger ON student;
# 删除函数
DROP FUNCTION student_delete_function();

测试触发器

student表新增数据
INSERT INTO student ("student_id", "name", "age", "gender", "address", "phone", "grade") VALUES (4, 'John Doe', 18, 'Male', 'Beijing', '1234567890', 'Grade 10');
student表修改数据
UPDATE student SET "name" = 'John Doe', "age" = 18, "gender" = 'Male', "address" = 'Beijing', "phone" = '1234567890', "grade" = 'Grade 11' WHERE "student_id" = 4;
student表删除数据
DELETE FROM student WHERE student_id = 4;

PostgreSQL使用触发器的优缺点

触发器的优点
  1. 数据完整性:触发器可以用于实施数据完整性约束,例如在插入或更新数据之前进行验证。
  2. 自动化操作:触发器可以自动执行一系列操作,无需手动干预。这可以提高开发效率并减少人为错误。
  3. 数据一致性:通过触发器,可以确保数据库中的数据保持一致性,例如在更新操作时自动更新相关字段。
  4. 日志记录:触发器可以用于记录数据库中的操作,例如在插入、更新或删除数据时记录相关信息。
触发器的缺点
  1. 复杂性:触发器的创建和管理可能会增加数据库的复杂性。触发器的逻辑必须正确且易于理解,以避免潜在的错误和混乱。
  2. 性能影响:触发器的执行会增加数据库的负载,特别是在处理大量数据时。过多或复杂的触发器可能会导致性能下降。
  3. 隐式操作:触发器的存在可能会导致一些隐式的操作,这可能会使代码更难以理解和维护。开发人员需要注意触发器的存在,并确保其行为符合预期。

在使用触发器时,需要权衡其优点和缺点,并根据具体情况进行决策。触发器应该被谨慎使用,仅在确实需要自动化操作或确保数据完整性时使用。

PostgreSQL创建触发器BEGIN和END之间可以写什么样的语句

  1. SQL 查询语句:可以在触发器中执行 SELECT 语句来获取数据或进行计算。
  2. 数据操作语句:可以在触发器中执行 INSERT、UPDATE 或 DELETE 语句来修改数据。
  3. 变量声明和赋值语句:可以在触发器中声明变量,并使用赋值语句给变量赋值。
  4. 控制流语句:可以在触发器中使用 IF、CASE、LOOP 等控制流语句来实现条件逻辑。
  5. 函数调用语句:可以在触发器中调用自定义函数或内置函数来实现特定的逻辑。
  6. 异常处理语句:可以在触发器中使用异常处理语句来处理可能发生的异常情况。
  7. 其他 SQL 语句:可以在触发器中使用其他合法的 SQL 语句来满足特定需求。

需要注意的是,在触发器中执行的语句应该符合 PostgreSQL 的语法规范,并且要注意触发器的执行时机和触发条件,以避免出现不必要的问题。

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Linux 12:多线程2

1. 生产者消费者模型 生产者消费者模型有三种关系,两个角色,一个交易场所。 三种关系: 生产者之间是什么关系?竞争 - 互斥 消费者和消费者之间?竞争 - 互斥 消费者和消费者之间?互斥和同步 两个角色: 生产者和消费者 一个交…

【Apache POI】Java解析Excel文件并处理合并单元格-粘贴即用

同为牛马,点个赞吧! 一、Excel文件样例 二、工具类源码 import org.apache.poi.ss.usermodel.*; import org.apache.poi.ss.util.CellRangeAddress; import org.apache.poi.xssf.usermodel.XSSFWorkbookFactory; import org.springframework.web.multip…

mac M1 创建Mysql8.0容器

MySLQ8.0 拉取m1镜像 docker pull mysql:8.0创建挂载文件夹并且赋予权限 sudo chmod 777 /Users/zhao/software/dockerLocalData/mysql 创建容器并且挂载 docker run --name mysql_8 \-e MYSQL_ROOT_PASSWORDadmin \-v /Users/zhao/software/dockerLocalData/mysql/:/var/l…

利用patch-package补丁,解决H5预览PDF时电子签章不显示问题

利用patch-package补丁,解决H5预览PDF时电子签章不显示问题 一、问题描述 在生产环境中,遇到了一个紧急的技术问题:用户在移动端H5页面上查看电子票时,PDF文件预览功能正常,但其中的电子签章未能正常显示。这一问题直…

C++ AVL树

目录 ​编辑 0.前言 1.AVL树的概念 1.1 平衡因子 1.2 AVL树的性质 2.AVL树节点的定义 3.AVL树的插入 4.AVL树的旋转 4.1 左单旋(LL旋转) 4.2 右单旋(RR旋转) 4.3 右左旋(RL旋转) 4.4 左右旋&…

集群架构-web服务器(接入负载均衡+数据库+会话保持redis)--15454核心配置详解

紧接着前面的集群架构深化—中小型公司(拓展到大型公司业务)–下面图简单回顾一下之前做的及故障核心知识总结(等后期完全整理后,上传资源希望能帮大家) web集群架构-接入负载均衡部署web02服务器等 web集群-搭建web0…

介绍 Elasticsearch 中的 Learning to Tank - 学习排名

作者:来自 Elastic Aurlien Foucret 从 Elasticsearch 8.13 开始,我们提供了原生集成到 Elasticsearch 中的学习排名 (learning to rank - LTR) 实现。LTR 使用经过训练的机器学习 (ML) 模型为你的搜索引擎构建排名功能。通常,该模型用作第二…

postman接口测试实战篇

击杀小游戏接口测试 接口测试简单介绍击杀小游戏代码下载单接口测试(postman)接口关联并参数化接口测试简单介绍 首先思考两个问题:1.接口是什么?2.接口测试是什么? 1.我们总是把接口想的很复杂,其实呢,它就是一个有特定输入和输出参数的交互逻辑处理单元,它不需要知…

通过 EMR Serverless Spark 提交 PySpark 流任务

在大数据快速发展的时代,流式处理技术对于实时数据分析至关重要。EMR Serverless Spark提供了一个强大而可扩展的平台,它不仅简化了实时数据处理流程,还免去了服务器管理的烦恼,提升了效率。本文将指导您使用EMR Serverless Spark…

PostgreSQL使用(二)

说明:本文介绍PostgreSQL的DML语言; 插入数据 -- 1.全字段插入,字段名可以省略 insert into tb_student values (1, 张三, 1990-01-01, 88.88);-- 2.部分字段插入,字段名必须写全 insert into tb_student (id, name) values (2,…

[数据集][目标检测]导盲犬拐杖检测数据集VOC+YOLO格式4635张2类别

数据集格式:Pascal VOC格式YOLO格式(不包含分割路径的txt文件,仅仅包含jpg图片以及对应的VOC格式xml文件和yolo格式txt文件) 图片数量(jpg文件个数):4635 标注数量(xml文件个数):4635 标注数量(txt文件个数):4635 标注…

graham 算法计算平面投影点集的凸包

文章目录 向量的内积(点乘)、外积(叉乘)确定旋转方向numpy 的 cross 和 outernp.inner 向量与矩阵计算示例np.outer 向量与矩阵计算示例 python 示例生成样例散点数据图显示按极角排序的结果根据排序点计算向量转向并连成凸包 基本…

Linux云计算 |【第一阶段】ENGINEER-DAY3

主要内容: LVM逻辑卷管理、VDO、RAID磁盘阵列、进程管理 一、新建逻辑卷 1、什么是逻辑卷 逻辑卷(Logical Volume)是逻辑卷管理(Logical Volume Management,LVM)系统中的一个概念。LVM是一种用于磁盘管理…

C++ :友元类

友元类的概念和使用 (1)将类A声明为B中的friend class后,则A中所有成员函数都成为类B的友元函数了 (2)代码实战:友元类的定义和使用友元类是单向的 (3)友元类是单向的,代码实战验证 互为友元类 (1)2个类可以互为友元类,代码实战…

Intel和AMD用户再等等!微软确认Win11 24H2年底前登陆

微软近日确认,Windows 11 24H2版本将于2024年底前正式登陆使用英特尔和AMD处理器的PC。 根据微软介绍,Windows 11 24H2将作为传统功能更新,将在今年晚些时候提供给所有设备。 此前,微软已向搭载骁龙X Plus和X Elite系列处理器的Co…

VS2019安装MFC组件

VS2019支持的MFC版本是mfc140 ~ mfc142版本,它兼容VS2015、VS2017之前的老版本程序。 一、MFC的历史版本 MFC的历史版本如下: IDE发布时间工具集版本MSC_VERMSVCMFC版本dllVisual C6.01998V601200MSVC6.06.0mfc42.dll、mfcce400.dllVisual Studio 2002…

Linux的热插拔UDEV机制和守护进程

目录 一、Linux的热插拔UDEV机制 二、守护进程 2.1 守护进程概念和基本特点: 2.2 显示进程信息: 2.3 守护进程和后台进程的区别: 2.4 创建守护进程的步骤和守护进程的特征: 2.4.1 创建守护进程的步骤: 2.4.2 守…

前端不懂 Docker ?先用它换掉常规的 Vue 项目部署方式

本项目代码已开源,具体见: 前端工程:vue3-ts-blog-frontend 后端工程:express-blog-backend 数据库初始化脚本:关注公众号程序员白彬,回复关键字“博客数据库脚本”,即可获取。 为什么需要容器化…

如何在 Mac 上下载安装植物大战僵尸杂交版? 最新版本 2.2 详细安装运行教程问题详解

植物大战僵尸杂交版已经更新至2.2了,但作者只支持 Windows、手机等版本并没有支持 MAC 版本,最近搞到了一个最新的杂交 2.2 版本的可以在 Macbook 上安装运行的移植安装包,试了一下非常完美能够正常在 MAC 上安装运行,看图&#x…

Linux云计算 |【第一阶段】ENGINEER-DAY5

主要内容: SELinux、系统故障修复、HTTPD/FTP服务搭建、防火墙策略管理、服务管理 一、SELinux安全制度 SELinux(Security-Enhanced Linux),美国NSA国家安全局主导开发,一套增强Linux系统安全的强制访问控制体系&…