当前位置: 首页 > ai >正文

MySQL的触发器:

目录

触发器的概念:

创建触发器:

查看触发器:

查看当前数据库的所有触发器的定义:

查看当前数据中某个触发器的定义:

从系统information_schema的TRIGGERS表中查询"salary_check_trigger"触发器的信息:

删除触发器:

优点:

缺点:

注意:


触发器的概念:

MySQL触发器(‌Trigger‌)是一种与数据库表关联的特殊存储程序,当指定事件(如INSERT、UPDATE、DELETE)发生时由数据库‌自动触发执行‌。它用于在数据变更前后执行自定义逻辑,确保数据的一致性和业务规则。

触发器是由事件来触发某个操作,这些事件包括INSERT、UPDATE、DELETE事件。所谓事件就是指用户的动作或者出发某项行为。如果定义了触发程序,当数据库执行这些语句的时候,就相当于事件发生了,就会自动激发触发器执行相应的操作。

创建触发器:

CREATE TRIGGER 触发器名称
{BEFORE | AFTER}{INSERT | UPDATE | DELETE} ON 表名
FOR EACH ROW
触发器执行的语句块;

表名:表示触发器监控的对象。

BEFORE | AFTER:表示触发的时间。BEFORE表示在事件之前触发,AFTER表示在事件之后触发。

INSERT | UPDATE | DELETE:表示触发的事件。INSERT插入记录时触发,UPDATE更新记录时触发,DELETE删除记录时触发。

触发器执行的语句块:可以是单条SQL语句,也可以是BEGIN...END结构组成的复合语句块。

如果使用了BEGIN...END:

DELIMITER $
CREATE TRIGGER 触发器名
{BEFORE | AFTER} {INSERT | DELETE | UPDATE} ON 表名
FOR EACH ROW
BEGIN
执行的SQL语句
END $
DELIMITER ;

查看触发器:

查看数据库中已经存在的触发器的定义、状态和语法信息等。

查看当前数据库的所有触发器的定义:

SHOW TRIGGERS;

查看当前数据中某个触发器的定义:

SHOW CREATE TRIGGER 触发器名;

从系统information_schema的TRIGGERS表中查询"salary_check_trigger"触发器的信息:

SELECT * FROM information_schema.TRIGGERS;

删除触发器:

DROP TRIGGER [IF EXISTS] 触发器名;

优点:

触发器可以确保数据的完整性。可以帮助记录操作日志。还可以用在操作数据前,对数据进行合法性检查。

缺点:

触发器最大的一个问题就是可读性差。因为触发器存储在数据库中,并且由事件驱动,这就意味这触发器有可能不受应用层的控制。

相关数据的变更,可能会导致触发器出错。

注意:

如果在子表中定义了外键约束,并且外键制定了ON UPDATE/DELETE CASCADE/SET NULL子句,此时修改父表被引用的键值或者删除附表被引用的记录行时,也会引起子表的修改和删除操作,此时基于子表的UPDATE和DELETE语句定义的触发器并不会被激活。

总结:

MySQL触发器是一种与表关联的特殊存储程序,在指定事件(INSERT/UPDATE/DELETE)发生时自动执行。通过CREATE TRIGGER语法创建,可设置在操作前(BEFORE)或后(AFTER)触发,支持单条SQL或复合语句块。触发器能确保数据一致性、记录操作日志和数据校验,但存在可读性差、不易维护的缺点。可通过SHOW TRIGGERS查看触发器,使用DROP TRIGGER删除。需注意外键约束可能影响触发器的激活。

http://www.xdnf.cn/news/17259.html

相关文章:

  • 温室韭菜收割机的设计cad【12张】三维图+设计说明书
  • 9:USB摄像头的最后一战(上):MP4音视频合封!
  • Redis(九):Redis高并发高可用(集群Cluster)
  • Javascript中的一些常见设计模式
  • react+echarts实现变化趋势缩略图
  • Elasticsearch:在向量搜索中使用 Direct IO
  • 富士 Instax 12 和 Instax Mini 11 有什么区别?推荐购买哪一款?
  • Microsoft Dynamics AX 性能优化解决方案
  • 【Python-Day 38】告别通用错误!一文学会创建和使用 Python 自定义异常
  • 临床医学 RANDOM SURVIVAL FORESTS(randomSurvivalForest)-2 python 例子
  • 【GPT-OSS 全面测评】释放推理、部署和自主掌控的 AI 新纪元
  • Redis对象编码
  • 微算法科技(NASDAQ:MLGO)使用循环QSC和QKD的量子区块链架构,提高交易安全性和透明度
  • 如何 让ubuntu 在root 下安装的docker 在 普通用户下也能用
  • 基于大数据的地铁客流数据分析预测系统 Python+Django+Vue.js
  • element plus table 表格操作列根据按钮数量自适应宽度
  • 并发编程(五)ThreadLocal
  • 智慧工业设备缺陷检测准确率↑32%:陌讯多模态融合算法实战解析
  • 微软XBOX游戏部门大裁员
  • 6.Linux 系统上的库文件生成与使用
  • 谷粒商城:检索服务
  • 解决Ollama外部服务器无法访问:配置 `OLLAMA_HOST=0.0.0.0` 指南
  • 深度剖析主流AI大模型的编程语言与架构选择:行业实践与技术细节解读
  • 苹果iPhone 17系列将发售,如何解决部分软件适配问题引发讨论
  • 《Hive、HBase、StarRocks、MySQL、OceanBase 全面对比:架构、优缺点与使用场景详解》
  • k8s调度问题
  • Charles中文版抓包工具功能解析,提升API调试与网络性能优化
  • ArgoCD 与 GitOps:K8S 原生持续部署的实操指南
  • 微软披露Exchange Server漏洞:攻击者可静默获取混合部署环境云访问权限
  • 31-数据仓库与Apache Hive-Insert插入数据