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

news2024/11/13 15:02:03

在这里插入图片描述

在 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 THEN
			INSERT 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 THEN
			UPDATE 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 THEN
			DELETE 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.coloradmin.cn/o/1940353.html

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

相关文章

docker的学习(二):docker常用的高级技术总结

简介 docker的一些知识点的总结 UnionFS 分层,轻量级,高性能的文件系统,支持一层层的叠加功能来修改文件系统。 一次同时加载多个文件系统,把各层文件系统叠加起来,最终文件系统会包含所有底层的文件和目录&#xf…

【java SE语法篇】1.运算符

目录 1. 运算符和表达式2. 算数运算符3. 隐式转换4. 强制转换5. 自增自减运算符6. 赋值运算符7. 扩展运算符8. 关系运算符9. 逻辑运算符9.1 & 和 | 的使用:9.2 ^(异或)的使用:9.3 !(取反)的使用&#x…

2024年技校大数据实验室建设及大数据实训平台整体解决方案

随着信息技术的迅猛发展,大数据已成为推动产业升级和社会进步的重要力量。为适应市场需求,培养高素质的大数据技术人才,技校作为职业教育的重要阵地,亟需加强大数据实验室的建设与实训平台的打造。本方案旨在提出一套全面、可行的…

如何制作u盘启动盘_制作U盘启动盘详细图文教程

如何制作u盘启动盘?一个U盘如果不做成启动盘的话,就只能当存储用。如果一个U盘做成启动盘的话,可以通过U盘启动进入PE,我们就可以对电脑进行重装系统或分区等一些操作使用了,这个主要用于电脑需要救急的情况下使用。用…

jmeter录制脚本做压力测试

1.录制 第一步 设置浏览器代理,我用的火狐。谷歌、IE也是都可以。 我把端口号改成8082了,这个无所谓的,只要不冲突就可以。 紧接着要往浏览器里添加证书。直接搜索证书。把jmeter的证书导入浏览器。 2.在jmeter里设置 添加线程组、http代…

Another-redis-desktop-manager+ffmpeg

一、Another-redis-desktop-manager 1.点击链接下载:Release v1.6.6 qishibo/AnotherRedisDesktopManager GitHub 2. 傻瓜式安装 二、ffmpeg 1.下载:Builds - CODEX FFMPEG gyan.dev 2.下载对应版本 3.添加环境变量:添加到path里&am…

Intent的基本使用

1.Intent是什么? Intent用于Android程序中各组件(Activity、BroadcastReceive、Service)的交互,并且可以在组件之间传递数据,分为显式Intent和隐式Intent。 Intent是各个组件之间信息沟通的桥梁,既能在Ac…

【24年7月】最新Hexo+GitHubPages搭建个人博客【一】

Hexo 是一个高效的静态网站生成器,使用简洁的 Markdown(或其他模板引擎)编写内容,支持丰富的插件和主题,允许用户轻松定制网站。它通过将文本转换为静态HTML页面,使得网站加载速度快,易于部署&a…

Linux操作系统的有关常用的命令

1.linux系统的概述 1.1 什么是Linux系统? Linux,全称GNU/Linux,是一种免费使用和自由传播的类UNIX操作系统,其内核由林纳斯本纳第克特托瓦 兹(Linus Benedict Torvalds)于1991年10月5日首次发布,它主要受…

塔子哥的题解点赞方案-美团2023笔试(codefun2000)

题目链接 塔子哥的题解点赞方案-美团2023笔试(codefun2000) 题目内容 塔子哥写了 n 篇题解,编号从 1 到 n,但是塔子哥忘了每篇题解有多少人点赞了。 现在他有如下两种信息: 1、每篇题解的点赞量都为正数,且不超过 m。 2、第 i 篇…

2024LitCTFmisc复现

secret 这首音乐好听,听完了,中间有段杂音 去AU看看 中间有一段藏了东西,放大 出flag了 flag{Calculate_Step_By_Step} 原铁,启动! 解压出来是一张二维码 扫出来是原神 去010看看 看到有压缩包,提取出来 …

关于集成网络变压器的RJ45网口

集成网络变压器的RJ45网口是一种将网络变压器与RJ45接口集成在一起的网络连接解决方案。这种集成设计具有多项优势,使其在现代网络设备中得到广泛应用。 优势与特点 1. **空间节省**:集成设计减少了组件数量和连接线缆长度,有助于节省设备内…

Adobe Premiere Pro(Pr)安装包软件下载

一、简介 Adobe Premiere Pro(简称Pr)是由Adobe公司开发的一款功能强大的视频编辑软件。它支持多平台使用,包括Windows和Mac系统,并且拥有良好的兼容性和高效的性能。Premiere Pro不仅提供了视频剪辑、特效添加、音频处理等基本功…

监控易V7.6.6.15全新升级14:设置功能全面优化

随着企业IT架构的不断发展,对运维管理的需求也日益增加。为了满足广大用户对运维管理的更高需求,监控易系统近期完成了一次重要版本升级。本次升级在原有功能的基础上,对设置功能进行了全面优化和新增,旨在为用户提供更加灵活、高…

系统架构师(每日一练5)

每日一练 1.某企业准备将四个工人甲、乙、丙、丁分配在A、B、C、D四个岗位。每个工人由于技术水平不同,在不同岗位上每天完成任务所 需的工时见下表。适当安排岗位,可使四个工人以最短的总工时()全部完成每天的任务。答案与解析 ABCD甲7523乙9437丙547…

【每日一练】python编写一个简易计算器

程序代码: #循环语句,条件为真所以循环执行 while True: #定义两个数的变量和运算符号 num1 float(input("第一个数:")) num2 float(input("第一个数:")) syminput("选择运算符 - * /:") #判断运算符号 …

《python语言程序设计》第6章2题(求一个整数各个数字的和)编写一个函数

求一个整数各个数字的和编写一个函数,计算一个整数各个数字的和, def sumDigits(n):a n // 100b n % 100 // 10c n % 100 % 10print(f"{n}数,分成个,十,百,{a}{b}{c}", a b c)sumDigits(23…

算法类学习笔记 ———— 红绿灯检测

文章目录 介绍基于传统视觉方法的检测基于颜色和边缘信息基于背景抑制 基于深度学习的检测特征金字塔网络(FPN)红绿灯检测特征金字塔自下而上自上而下横向连接 特征融合SSD红绿灯检测 高精度地图结合 介绍 红绿灯检测就是获取红绿灯在图像中的坐标以及它…

73.如何通过自开发的T-CODE找到源代码

目录 步骤1,利用SAP的事务代码表(‌TSTC)‌-SE16 步骤2,查询源代码 方法1 - SE80 方法2 - SE38 步骤1,利用SAP的事务代码表(‌TSTC)‌-SE16 通过输入特定的事务代码(‌tcode&am…

web前端学习笔记Day02

web学习Day02 一、页面布局 盒子模型 盒子将页面的所有标签都包含在了一个矩形区域content(内容区域)->padding(内边距区域)->border(边框区域)->margin(外边距区域) div标签: 一行只能显示一个(独占一行)width默认为父元素宽度&#xff0c…