MySQL触发器Trigger加载以及目前局限

这篇具有很好参考价值的文章主要介绍了MySQL触发器Trigger加载以及目前局限。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

  • GreatSQL社区原创内容未经授权不得随意使用,转载请联系小编并注明来源。
  • GreatSQL是MySQL的国产分支版本,使用上与MySQL一致。
  • 作者: 亮
  • 文章来源:GreatSQL社区原创

概念介绍

首先需要知道MySQL中触发器特点,以及表table相关触发器加载方式

  1. MySQL中单个trigger仅支持单事件触发即单个触发器不支持类似insert or update等多事件语法操作,如果需要多事件都能被同一个表触发,只能分别建立多个对应trigger。
  2. 触发器加载首先需要加载触发器分组列表Trigger_chain,后续再将具体触发器添加到Trigger_chain内。
  3. 表table属性内可包含多个触发器分组列表Trigger_chain,Trigger_chain用于加载不同类别的触发器,主要类别有insert、update或delete类型。
  4. 触发器分组列表Trigger_chain内m_triggers又可加载多个具体属于该分组的具体触发器。

触发器分组列表Trigger_chain加载过程

1.当打开表table时通过如下函数过程加载触发器分组列表Trigger_chain

函数open_tables->open_and_process_table->handle_table->add_tables_and_routines_for_triggers

2.跟踪add_tables_and_routines_for_triggers函数内参数定义

查看TRG_EVENT_MAX定义

enum enum_trigger_event_type {

TRG_EVENT_INSERT = 0,

TRG_EVENT_UPDATE = 1,

TRG_EVENT_DELETE = 2,

TRG_EVENT_MAX

};

查看TRG_ACTION_MAX定义

enum enum_trigger_action_time_type {

TRG_ACTION_BEFORE = 0,

TRG_ACTION_AFTER = 1,

TRG_ACTION_MAX

};

查看函数get_triggers内可知触发器加载存储方式是二维数组m_trigger_map内

/// Triggers grouped by event, action_time.

Trigger_chain *m_trigger_map[TRG_EVENT_MAX] [TRG_ACTION_MAX];
  • 综合TRG_EVENT_MAX和TRG_ACTION_MAX以及m_trigger_map可以看出目前MySQL触发器加载设计方式存在一定的弊端,即TRG_EVENT分组只能按insert、update、delete区分,单次触发事件只能触发执行对应分组内的触发器,对于需要扩展单触发器同时支持多事件的方式如:insert or update 、update or delete 等方式将需要较大的改造。

触发器分组列表Trigger_chain添加具体触发器trigger过程

1.打开过的table其触发器通过如下函数过程加载

  • 函数open_tables->open_table_entry_fini->check_n_load

2.具体加载过程

  • 通过函数 check_n_load内调用load_triggers函数从磁盘加载已经建好的触发器t。

  • 然后调用create_trigger_chain函数获取到前期已经加载的触发器分组列表Trigger_chain。

  • 最后触发器分组列表Trigger_chain调用add_trigger添加具体触发器t至分组列表内。

当目标表table有insert、update或delete操作时,即会触发执行对应分组列表Trigger_chain内相应分组的触发器。

说明:MySQL在新增和删除触发器的操作时都会关闭当前已经打开的table句柄,在下次打开table时会重新load相应的trigger。


Enjoy GreatSQL 😃

关于 GreatSQL

GreatSQL是由万里数据库维护的MySQL分支,专注于提升MGR可靠性及性能,支持InnoDB并行查询特性,是适用于金融级应用的MySQL分支版本。

相关链接: GreatSQL社区 Gitee GitHub Bilibili

GreatSQL社区:

社区博客有奖征稿详情:https://greatsql.cn/thread-100-1-1.html

MySQL触发器Trigger加载以及目前局限

技术交流群:

微信:扫码添加GreatSQL社区助手微信好友,发送验证信息加群

MySQL触发器Trigger加载以及目前局限文章来源地址https://www.toymoban.com/news/detail-446031.html

到了这里,关于MySQL触发器Trigger加载以及目前局限的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【Unity】Trigger触发器失效没反应的解决办法

    今天遇到了一个问题,创建的角色进入传送门的时候无法传送。 看了所有的代码,确定没有问题之后,把目标瞄准到了Trigger上,在触发中添加了输出之后发现,触发器确实没有触发 众所周知,触发器触发需要两者都有触发器,其中一者勾选Is Trigger,其中一者有刚体就可以了

    2024年02月13日
    浏览(56)
  • Unity_网格碰撞器-MeshCollider-触发器-Trigger 网格碰撞器(MeshCollider)内部没有触发检测 只在表面有触发检测

    Unity的触发器功能很好,但是也有问题。我来讲讲问题以及解决方案。 先上视频给大家看看效果: 自制触发器 首先约定几个特殊名词。 基元游戏物体:Cube、Sphere之类的。 基元碰撞器:BoxCollider、SphereCollider之类的。 基元触发器:把基元碰撞体的IsTrigger选中,就是基元触发器

    2024年02月03日
    浏览(43)
  • 第68讲:MySQL触发器的核心概念以及常见的触发类型应用案例

    触发器是与表中数据相关的数据库对象,当表中的数据产生inster、update、delete这类操作时,可以通过触发器在这些动作之前或者之后,去完成相应的操作,例如向表中插入一条数据,插入数据之后通过触发器完成一些操作。 在触发器中会定义很多的SQL语句集合,当满足执行触

    2024年02月05日
    浏览(40)
  • MySQL-SQL存储函数以及触发器详解

    ♥️ 作者:小刘在C站 ♥️ 个人主页:  小刘主页  ♥️ 努力不一定有回报,但一定会有收获加油!一起努力,共赴美好人生! ♥️ 学习两年总结出的运维经验,以及思科模拟器全套网络实验教程。专栏: 云计算技术 ♥️小刘私信可以随便问,只要会绝不吝啬,感谢CSD

    2024年02月11日
    浏览(59)
  • 【MySQL触发器】触发器的使用、创建、修改及删除

    一、什么是触发器 二、创建触发器 ①创建一个insert事件触发器 ②创建一个delete 事件触发器  三、触发器包含多条执行语句 四、查看触发器  ①SHOW TRIGGERS语句查看触发器 ②查看系统表triggers实现查看触发器   五、触发器的删除       当我们对一个表进行数据操作时,需

    2023年04月08日
    浏览(57)
  • MySQL | MySQL触发器

    目录 一、创建触发器 1.2 创建只有一个执行语句的触发器 1.2 创建有多个执行语句的触发器 二、查看触发器 2.1 利用SHOW TRIGGERS语句查看触发器信息 2.2 在triggers表中查看触发器信息 三、删除触发器 触发器是一个特殊的存储过程,不同的是,执行存储过程要使用CALL语句来调用,

    2024年02月14日
    浏览(42)
  • MySQL 触发器

    触发器是与表有关的数据库对象,指在insert/update/delete之前或之后,触发并执行触发器中定义SQL语句集合。触发器的这种特性可以协助应用在数据库端确保数据的完整性,日志记录,数据校验等操作。 使用别 名OLD 和 NEW 来引用触发器中发生变化的记录内容,这与其他的数据库

    2024年02月08日
    浏览(43)
  • MySQL进阶——触发器

    同存储过程和函数类似,MySQL中的触发器也是存储在系统内部的一段程序代码,可以把它看作是一个特殊的存储过程。所不同的是,触发器无需人工调用,当程序满足定义条件时就会被MySQL自动调用。这些条件可以称为触发事件,包括INSERT、UPDATE和DELETE操作。 从MySQL5.7开始,可

    2024年02月04日
    浏览(49)
  • MySQL-触发器

    目录 🍁触发器简介 🍁创建触发器 🍃创建 BEFORE 类型触发器 🍃创建 AFTER 类型触发器 🍁删除触发器(DROP TRIGGER) 🍃删除触发器 🍁语法总结 🍃insert 🍃delete 🍃update 🦐:MySQL专栏         MySQL 数据库中触发器是一个特殊的存储过程,不同的是执行存储过程要使用 CAL

    2024年01月16日
    浏览(41)
  • 【MySQL进阶】MySQL触发器详解

    序号 系列文章 7 【MySQL基础】运算符及相关函数详解 8 【MySQL基础】MySQL多表操作详解 9 【MySQL进阶】MySQL事务详解 10 【MySQL进阶】MySQL视图详解 大家好,我是小杨!前面我已经为大家介绍了MySQL中的进阶知识-视图,那么今天我们就给大家讲解MySQL中的触发器这部分的相关内容,

    2024年02月03日
    浏览(54)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包