GaussDB数据库SQL系列-触发器

目录

一、前言

二、触发器概念

三、GaussDB数据库中的触发器

1、语法格式

2、创建步骤

3、注意事项

4、附:表和视图上支持的触发器种类

四、GaussDB数据库中的示例

示例一、在GaussDB数据库中创建一个触发器,以便在插入新记录时自动将记录的创建时间设置为当前时间

示例二、在GaussDB数据库中创建一个触发器,当向测试表test_1中INSERT 数据的时候,同时向测试表test_2中插入相同的数据

五、小结

一、前言

GaussDB是一个高度可靠、可扩展、高性能的数据库管理系统,用于支持企业级应用、数据仓库、数据科学和实时分析等场景。它提供了丰富的功能和工具,以帮助开发和管理员有效地管理数据。

在GaussDB中,触发器是一种重要的数据库对象,用于在满足特定条件时自动触发预定义的操作。通过使用触发器,您可以实现数据的实时监控、验证、日志记录和其他自动化任务。本篇文章将介绍GaussDB数据库中触发器的基本概念、创建以及示例,并简要总结触发器的优缺点。

二、触发器概念

触发器是GaussDB数据库中的一种数据库对象,它是一种自动触发的SQL代码块,用于在满足特定条件时执行预定义的操作。触发器可以用于监控数据库中的数据变化、实施业务规则、日志记录等。与存储过程不同,触发器是自动触发的,无需显式调用。

三、GaussDB数据库中的触发器

创建一个触发器。 触发器将与指定的表或视图关联,并在特定条件下执行指定的函数。

1、语法格式

CREATE [ CONSTRAINT ] TRIGGER trigger_name
{ BEFORE | AFTER | INSTEAD OF } { event [ OR ... ] } ON table_name[ FROM referenced_table_name ]{ NOT DEFERRABLE | [ DEFERRABLE ] { INITIALLY IMMEDIATE | INITIALLY DEFERRED } }[ FOR [ EACH ] { ROW | STATEMENT } ][ WHEN ( condition ) ]EXECUTE PROCEDURE function_name ( arguments );

主要参数说明:

  • CONSTRAINT:可选项,指定此参数将创建约束触发器,即触发器作为约束来使用。除了可以使用SET CONSTRAINTS调整触发器触发的时间之外,这与常规触发器相同。 约束触发器必须是AFTER ROW触发器。
  • trigger_name:触发器名称,该名称不能限定模式,因为触发器自动继承其所在表的模式,且同一个表的触发器不能重名。 对于约束触发器,使用SET CONSTRAINTS修改触发器行为时也使用此名称。命名规范:符合标识符命名规范的字符串,且最大长度不超过63个字符。
  • BEFORE:触发器函数是在触发事件发生前执行。
  • AFTER:触发器函数是在触发事件发生后执行,约束触发器只能指定为AFTER。
  • INSTEAD OF:触发器函数直接替代触发事件。
  • event:启动触发器的事件,取值范围包括:INSERT、UPDATE、DELETE或TRUNCATE,也可以通过OR同时指定多个触发事件。
  • table_name:需要创建触发器的表名称。取值范围:数据库中已经存在的表名称。
  • referenced_table_name:约束引用的另一个表的名称。 只能为约束触发器指定,常见于外键约束。由于当前不支持外键,因此不建议使用。取值范围:数据库中已经存在的表名称。
  • DEFERRABLE | NOT DEFERRABLE:约束触发器的启动时机,仅作用于约束触发器。这两个关键字设置该约束是否可推迟。
  • INITIALLY IMMEDIATE | INITIALLY DEFERRED:如果约束是可推迟的,则这个子句声明检查约束的缺省时间,仅作用于约束触发器。
  • FOR EACH ROW | FOR EACH STATEMENT:触发器的触发频率。FOR EACH ROW是指该触发器是受触发事件影响的每一行触发一次。FOR EACH STATEMENT是指该触发器是每个SQL语句只触发一次。未指定时默认值为FOR EACH STATEMENT。约束触发器只能指定为FOR EACH ROW。
  • condition:决定是否实际执行触发器函数的条件表达式。当指定WHEN时,只有在条件返回true时才会调用该函数。
  • function_name:用户定义的函数,必须声明为不带参数并返回类型为触发器,在触发器触发时执行。
  • arguments:执行触发器时要提供给函数的可选的以逗号分隔的参数列表。参数是文字字符串常量,简单的名称和数字常量也可以写在这里,但它们都将被转换为字符串。 请检查触发器函数的实现语言的描述,以了解如何在函数内访问这些参数。

2、创建步骤

1)确定触发器的目的和条件:

首先,您需要确定触发器的目的和条件。这包括确定您希望在什么情况下触发触发器(例如,在插入、更新或删除数据时)以及触发器的具体条件(例如,仅在特定时间或特定用户执行操作时触发)。

2)编写触发器的代码:

根据您的需求,编写触发器的SQL代码。这可以包括SELECT、INSERT、UPDATE、DELETE等语句以及逻辑控制语句(例如IF语句)。

3)定义触发器的参数:

定义触发器的参数,例如要监控的表、触发时机(BEFORE/AFTER)、触发事件(INSERT/UPDATE/DELETE)等。

4)创建触发器:

使用CREATE TRIGGER语句创建触发器,并指定上述定义好的参数和代码。

3、注意事项

  • 当前仅支持在普通行存表上创建触发器,不支持在列存表、临时表、unlogged表等类型表上创建触发器。
  • 如果为同一事件定义了多个相同类型的触发器,则按触发器的名称字母顺序触发它们。
  • 执行触发器语句时是用触发器创建者的身份进行权限判断的。
  • 执行创建触发器操作的用户需要拥有指定表的TRIGGER权限或被授予了CREATE ANY TRIGGER权限。
  • 触发器常用于多表间数据关联同步场景,对SQL执行性能影响较大,不建议在大数据量同步及对性能要求高的场景中使用。

4、附:表和视图上支持的触发器种类

四、GaussDB数据库中的示例

示例一、在GaussDB数据库中创建一个触发器,以便在插入新记录时自动将记录的创建时间设置为当前时间。

以下是一个简单的示例,演示了如何在GaussDB数据库中创建一个触发器,以便在插入新记录时自动将记录的创建时间设置为当前时间。

--定义一个触发器函数,用于设置创建时间字段的值:
CREATE OR REPLACE FUNCTION set_created_at()
RETURNS TRIGGER 
AS $$
BEGINNEW.date = NOW();  RETURN NEW;
END
$$ 
LANGUAGE plpgsql;--创建一个INSERT触发器
CREATE TRIGGER set_created_at_trigger
BEFORE INSERT ON test_1
FOR EACH ROW
EXECUTE PROCEDURE set_created_at();--执行INSERT触发事件并检查触发结果
INSERT INTO test_1 VALUES(6,'');
SELECT * FROM test_1;

说明:

1、其中test_1为测试表,date为测试表的字段名。

2、NEW是一个特殊的关键字,代表正在插入的新记录。当一个触发器被触发时,例如在INSERT操作发生时,NEW可以用来引用正在被插入的新记录。这样,你就可以在触发器中使用NEW来引用正在进行操作的数据。

3、参数“BEFORE”、“FOR EACH ROW”等可参见上文语法参数说明。

示例二、在GaussDB数据库中创建一个触发器,当向测试表test_1中INSERT 数据的时候,同时向测试表test_2中插入相同的数据。

以下是在GaussDB数据库中创建一个触发器,当向测试表test_1中INSERT 数据的时候,触发器被触发,并向测试表test_2中插入相同的数据。

--创建触发器函数
CREATE OR REPLACE FUNCTION tri_insert_func() 
RETURNS TRIGGER 
AS $$
DECLARE
BEGININSERT INTO test_2 VALUES(NEW.id, NEW.date);RETURN NEW;END
$$ 
LANGUAGE PLPGSQL;--创建INSERT触发器
CREATE TRIGGER insert_trigger
BEFORE INSERT ON test_1
FOR EACH ROW
EXECUTE PROCEDURE tri_insert_func();--执行INSERT触发事件并检查触发结果
INSERT INTO test_1(id,date) VALUES(1,current_timestamp);SELECT *, 'test_1' as table_n FROM test_1
UNION ALL
SELECT *, 'test_2' as table_n FROM test_2;

更多示例可参见官方文档 :

CREATE TRIGGER_云数据库 GaussDB_主备版_3.x版本_SQL参考_SQL语法_华为云

CREATE TRIGGER_云数据库 GaussDB_分布式_3.x版本_SQL参考_SQL语法_华为云

五、小结

GaussDB数据库中的触发器是一种强大的工具,可用于自动化数据处理、数据验证、日志记录等任务。通过使用触发器,您可以提高数据一致性、减少数据冗余、实施业务规则并增强数据安全性。本文介绍了GaussDB数据库中触发器的基本概念、创建步骤和示例。希望能够帮助您更好地了解和使用GaussDB中的触发器功能。

——结束

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

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

相关文章

论文笔记--Toolformer: Language Models Can Teach Themselves to Use Tools

论文笔记--Toolformer: Language Models Can Teach Themselves to Use Tools 1. 文章简介2. 文章概括3 文章重点技术3.1 Toolformer3.2 APIs 4. 文章亮点5. 原文传送门 1. 文章简介 标题:Toolformer: Language Models Can Teach Themselves to Use Tools作者&#…

堆详解(C语言实现)

文章目录 写在前面1. 堆的概念和性质1.1 堆的概念1.2 堆的性质 2 堆的实现2.1 堆结构的定义2.2 堆的初始化2.3 堆的插入2.3.1 向上调整算法2.3.2 堆的插入元素过程 2.4 堆的删除2.4.1 向下调整算法2.4.2 堆的删除元素过程 2.5 获取堆顶元素2.6 获取堆元素个数2.7 判断堆是否为空…

Spring Security 6.x 系列(6)—— 显式设置和修改登录态信息

一、前言 此篇是对上篇 Spring Security 6.x 系列(5)—— Servlet 认证体系结构介绍 中4.9章节显式调用SecurityContextRepository#saveContext进行详解分析。 二、设置和修改登录态 2.1 登录态存储形式 使用Spring Security框架,认证成功…

使用 ChatGPT 创建 Makefile 构建系统:从 Docker 开始

使用 Docker 搭配 ChatGPT 创建 Makefile 构建系统 Makefile 构建系统是嵌入式软件团队实现其开发流程现代化的基础。构建系统不仅允许开发人员选择各种构建目标,还可以将这些构建集成到持续集成/持续部署 (CI/CD) 流程中。使用诸如 ChatGPT 这样的人工智能 (AI) 工…

深度剖析API接口测试工具的企业价值

随着企业软件开发的日益复杂和互联网应用的普及,API接口成为不同软件系统之间信息传递的桥梁。在这一背景下,API接口测试工具的应用变得愈加重要,对企业的发展和软件质量起到了关键性的作用。本文将深入探讨API接口测试工具在企业中的重要性&…

leetcode:2133. 检查是否每一行每一列都包含全部整数(python3解法)

难度:简单 对一个大小为 n x n 的矩阵而言,如果其每一行和每一列都包含从 1 到 n 的 全部 整数(含 1 和 n),则认为该矩阵是一个 有效 矩阵。 给你一个大小为 n x n 的整数矩阵 matrix ,请你判断矩阵是否为一…

matlab配置

matlab配置 windowslinux挂载安装MATLAB windows 按照这里一步步配置就行( 移动硬盘中软件备份中自取) linux linux配置步骤 挂载 sudo mount -t auto -o loop /media/oyk/Elements/ubuntu/MATLAB/R2017a_glnxa64_dvd1.iso ./matlab/安装MATLAB 挂载完成后,先…

SpringCloudAlibaba之Nacos的持久化和高可用——详细讲解

目录 一、Nacos持久化 1.持久化说明 2.安装mysql数据库5.6.5以上版本(略) 3.修改配置文件 二、nacos高可用 1.集群说明 2.nacos集群架构图 2.集群搭建注意事项 3.集群规划 4.搭建nacos集群 5.安装Nginx 6.配置nginx conf配置文件 7.启动nginx进行测试即可 一、Nacos持久…

laravel8中常用路由使用(笔记四)

目录 1、框架路由目录统一放该目录 2、基本路由,路由都调用Route方法 3、控制器使用路由 4、路由参数 5、路由组 6、命名路由 7、命令查看当前路由列表 8、路由缓存 在Laravel 8中,路由定义了应用程序中接受请求的方式。它们定义了URL和相应的控制器方法之间的…

13、LCD1602调试工具

LCD1602调试工具 使用LCD1602液晶屏作为调试窗口&#xff0c;提供类似Printf函数的功能&#xff0c;可实时观察单片机内部数据的变化情况&#xff0c;便于调试和演示。 main.c #include <REGX52.H> #include "LCD1602.h" #include "Delay.h"//存储…

【开源】基于JAVA的海南旅游景点推荐系统

项目编号&#xff1a; S 023 &#xff0c;文末获取源码。 \color{red}{项目编号&#xff1a;S023&#xff0c;文末获取源码。} 项目编号&#xff1a;S023&#xff0c;文末获取源码。 目录 一、摘要1.1 项目介绍1.2 项目录屏 二、功能模块2.1 用户端2.2 管理员端 三、系统展示四…

前端开发学习 (三) 列表功能

一、列表功能 1、列表功能 <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><meta http-equiv"X-UA-Compa…

锂电行业废水及母液除铊解决方案,除铊树脂技术

锂电池原材料和生产设备的制造、电池回收和处理等&#xff0c;产业的发展会带来铊排放问题。除了锂电池生产过 程中存在的铊污染外&#xff0c;企业的生活污水或者初期雨水也含有铊&#xff0c;因为铊是一种广泛存在于自然环境中的 元素&#xff0c;存在于饮用水、土壤和食物中…

高效视频剪辑:按指定时长批量分割视频,释放无尽创意

随着数字媒体技术的不断发展&#xff0c;视频剪辑已经成为日常生活中不可或缺的一部分。无论是制作电影、电视剧&#xff0c;还是创意生活短视频&#xff0c;视频剪辑都扮演着重要的角色。然而&#xff0c;对于许多非专业人士来说&#xff0c;视频剪辑可能是一项复杂而耗时的任…

27.0/多态/对象向上转型/向下转型/抽象类/抽象方法。

目录 27.1为什么使用多态? 27.1.2什么是多态 27.1.3对象多态 27.1.4多态的使用前提 27.2 向上转型 27.3向下转型 (面试题) 27.4抽象类和抽象方法 特点(面试题): 27.1为什么使用多态? 需求1&#xff1a;动物园让我们实现一个功能&#xff1a; 创建一个狗类 &#xff0c;狗…

Leetcode—739.每日温度【中等】

2023每日刷题&#xff08;四十二&#xff09; Leetcode—739.每日温度 单调栈实现思想 从右到左实现代码 class Solution { public:vector<int> dailyTemperatures(vector<int>& temperatures) {int n temperatures.size();stack<int> st;vector<i…

ensp 启动设备时报40错误,然后一直没有去管,再次进去就好了,我知道是配置虚拟机的时候修改了一些设置:

第一个阶段&#xff1a; 那时我是重置电脑之后就安装了ensp所以没有出现什么问题&#xff0c;&#xff08;那时没有导入ce6800和12800还有防火墙6000&#xff09; 第二个阶段&#xff1a; 因为有华为相关的实验要做&#xff0c;所以心血来潮打开了ensp&#xff08;路由器之前…

Digicert OV 代码签名介绍

Digicert OV 代码签名证书是一种数字证书&#xff0c;用于对软件代码进行数字签名。数字签名是一种验证软件来源和完整性的技术&#xff0c;通过使用私有密钥对代码进行签名&#xff0c;并在签名后使用公共密钥验证签名。 可基于更多平台&#xff0c;最大限度地提高分发量和收…

03、K-means聚类实现步骤与基于K-means聚类的图像压缩(2)

03、K-means聚类实现步骤与基于K-means聚类的图像压缩&#xff08;2&#xff09; 工程下载&#xff1a;K-means聚类实现步骤与基于K-means聚类的图像压缩 其他&#xff1a; 03、K-means聚类实现步骤与基于K-means聚类的图像压缩&#xff08;1&#xff09; 03、K-means聚类实现…

Linux 命令ln

1什么是链接 ln在Linux中 ln 命令的功能是为某一个文件在另外一个位置建立一个同步的链接&#xff0c;当我们需要在不同的目录&#xff0c;用到相同的文件时&#xff0c;我们不需要在每一个需要的目录下都放一个必须相同的文件&#xff0c;我们只要在某个固定的目录&#xff0…