首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

MySQL数据库触发器

1 引言         本文是对MySQL触发器的总结,从触发器概念出发,结合实例对创建触发器、使用触发器、删除触发器进行介绍。...2 触发器简介 MySQL触发器和存储过程一样,都是嵌入到MySQL的一段程序。触发器是由事件来触发某个操作,这些事件包括INSERT、UPDATE、DELETE。...如果定义了触发器,当数据库执行这些语句的时候就会激活触发器执行相应的操作,触发程序是与表有关的命令数据库对象,当表上出现特定事件,将激活该对象。   ...FOR EACH ROW BEGIN 语句执行列表 END         当触发器有至少一条的执行语句时,多条执行语句需要用BEGIN和END包裹,分别表示整个代码块的开始和结束...表中查看触发器   在information_schema数据库的triggers表中存放在MySQL数据库中的所有触发器,可以通过查询语句进行查看: select * from information_schema.triggers

1.6K10
您找到你想要的搜索结果了吗?
是的
没有找到

50多条实用mysql数据库优化建议

28.在所有的存储过程和触发器的开始处设置 SET NOCOUNT ON ,在结束时设置 SET NOCOUNT OFF .无需在执行存储过程和触发器的每个语句后向客户端发送 DONE_IN_PROC...例如: optimize table table_name 注意: analyze、check、optimize执行期间将对表进行锁定,因此一定注意要在MySQL数据库不繁忙的时候执行相关的操作。...这样一样,MySQL数据库引擎会在找到一条数据后停止搜索,而不是继续往后查少下一条符合记录的数据。 下面的示例,只是为了找一下是否有“中国”的用户,很明显,后面的会比前面的更有效率。...这样使用只让你的数据库的性能呈指数级的下降。这里的问题是:MySQL会不得不去执行 RAND()函数(很耗CPU时间),而且这是为了每一行记录去记行,然后再对其排序。...小心“永久链接” “永 久链接”的目的是用来减少重新创建MySQL链接的次数。当一个链接被创建了,它会永远处在连接的状态,就算是数据库操作已经结束了。

3.9K60

MySQL触发器

MySQL触发器 1.1. 定义 1.2. 创建触发器 1.2.1. 创建一行执行语句的触发器 1.2.2. 创建多行执行语句的触发器 1.3. 查看触发器 1.3.1....注意 MySQL触发器 定义 MySQL触发器和存储过程一样,都是嵌入到MysQL中的一段程序,不过触发器不要调用,而是由事件触发的,这些事件包括insert,update,delete语句,如果定义了触发程序...show triggers \G : 有条理的显示所有触发器 查看指定的触发器 如果需要查看指定的触发器,那么可以从information_schema数据库中的triggers表中查询指定的触发器...: 删除指定数据库中的触发器 db :数据库的名字 trigger_name :触发器的名字 触发器执行的顺序 我们建立的数据库一般都是InnoDB数据库,其上建立的表是事务性表,也就是事务安全的。...这时,若SQL语句或触发器执行失败,MySQL 会回滚事务,有: 如果 BEFORE 触发器执行失败,SQL 无法正确执行。 SQL 执行失败时,AFTER 型触发器不会触发。

5K20

mysql触发器

前言 近期遇到需要写触发器的需求,需要将A表中数据修改的信息,添加到B表中,之前比较少写,记录一下学习到的一些知识点 触发器的好处 使用触发器,把更改(如果需要,甚至还有之前和之后的状态)记录到另一个表非常容易...触发器关键字 在触发器中我们经常会用到NEW和OLD这两个关键字下面来分别了解一下 NEW是指刚刚插入到数据库的数据表中的一个域,。...VALUES (null,OLD.sync_table_name, OLD.gmt_create, OLD.gmt_modified, OLD.version,OLD.total); END 注意点 MySQL...但是对这部分内容点比较陌生,后面通过触发器关键字解决了这个问题,但是还是需要扩展一下binlog相关的知识点 MySQL的二进制日志binlog可以说是MySQL最重要的日志,它记录了所有的DDL和DML...语句(除了数据查询语句select),以事件形式记录,还包含语句所执行的消耗的时间,MySQL的二进制日志是事务安全型的

6.7K30

MySQL触发器

触发器概述  MySQL从 5 . 0 . 2 版本开始支持触发器MySQL触发器和存储过程一样,都是嵌入到MySQL服务器的一 段程序。...如果定义了触发程序,当数据库执行这些语句时候,就相当于事件发生 了,就会 自动 激发触发器执行相应的操作。...当对数据表中的数据执行插入、更新和删除操作,需要自动执行一些数据库逻辑时,可以使用触发器来 实现。...查看、删除触发器  方式1:查看当前数据库的所有触发器的定义 SHOW TRIGGERS 方式2:查看当前数据库中某个触发器的定义方式 SHOW CREATE TRIGGER 触发器名 方式3:从系统库...因为触发器存储在数据库中,并且由事件驱动,这就意味着触发器有可能 不受应用层的控制 。这对系统维护是非常有挑战的。 比如,创建触发器用于修改会员储值操作。

3.2K20

MySQL触发器

大家好,又见面了,我是全栈君 MySQL在5.0.2版本以上开始支持触发器触发器是有某些带有命令的时间来触发某些操作,这些事件包括insert语句、delete语句、update语句等。...触发器可以用于记录对数据库的操作。...1、创建mysql触发器: (1)创建具有单个执行语句的触发器 create trigger 触发器名称 before | after触发事件 on 表名 for each row 执行语句 before...timelog中插入当前操作的时间 更多:http://hovertree.com/menu/mysql/ (2)创建具有多个执行语句的触发器 create trigger 触发器名称 before...:是数据库中用于记录触发器信息的数据表; TRIGGER_NAME:用于指定要查看的触发器名称 3、删除触发器 droptrigger 触发器名称; 发布者:全栈程序员栈长,转载请注明出处:https

3.9K20

MySQL触发器

触发器和存储过程一样是一个能够完成特定功能、存储在数据 库服务器上的SQL片段,但是触发器无需调用,当对数据库表中的数据执行DML操作时自动触发这 个SQL片段的执行,无需手动条用。...在MySQL中,只有执行insert,delete,update操作时才能触发 触发器的执行 触发器的这种特性可以协助应用在数据库端确保数据的完整性 , 日志记录 , 数据校验 等操作 。...使用别名 OLD 和 NEW 来引用触发器中发生变化的记录内容,这与其他的数据库是相似 的。现在触发器还只支持行级触发,不支持语句级触发。...;   -- 添加数据,触发器自动执行并添加日志代码 insert into user values(1,'张三','123456'); 操作 -- 如果触发器trigger_test2存在,则先删除...,触发器自动执行并添加日志代码 update user set password = '888888' where uid = 1; 操作-NEW与OLD 格式 MySQL 中定义了 NEW 和 OLD

6.3K10

数据库原理与运用|MySQL数据库MySQL存储函数和触发器

文章目录 前言 MySQL储存函数 介绍 存储函数和储存过程的区别 格式 MySQL触发器 介绍 触发器特性 创建触发器 基本操作 总结 前言 上期详细说明了MySQL函数 MySQL储存函数 介绍...type参数用于指定存储函数的参数类型,该类型可以是MySQL数据库中所有支持的类型。 ​ (3)RETURNS type:指定返回值的类型。 ​...触发器和存储过程一样是一个能够完成特定功能、存储在数据库服务器上的SQL片段,但是触发器无需调用,当对数据库表中的数据执行DML操作时自动触发这个SQL片段的执行,无需手动条用。...在MySQL中,只有执行insert,delete,update操作时才能触发触发器的执行。触发器的这种特性可以协助应用在数据库端确保数据的完整性 , 日志记录 , 数据校验等操作 。...使用别名 OLD 和 NEW 来引用触发器中发生变化的记录内容,这与其他的数据库是相似的。现在触发器还只支持行级触发,不支持语句级触发。

2.1K10

数据库原理与运用|MySQL数据库MySQL存储函数和触发器

图片图片市场 https://market.cloud.tencent.com/文章目录前言MySQL储存函数介绍存储函数和储存过程的区别格式MySQL触发器介绍触发器特性创建触发器基本操作总结----...type参数用于指定存储函数的参数类型,该类型可以是MySQL数据库中所有支持的类型。(3)RETURNS type:指定返回值的类型。(4)characteristic:可选项,指定存储函数的特性。...触发器和存储过程一样是一个能够完成特定功能、存储在数据库服务器上的SQL片段,但是触发器无需调用,当对数据库表中的数据执行DML操作时自动触发这个SQL片段的执行,无需手动条用。...在MySQL中,**只有执行insert,delete,update操作时才能触发触发器的执行**。触发器的这种特性可以协助应用在数据库端确保数据的完整性 , 日志记录 , 数据校验等操作 。...使用别名 OLD 和 NEW 来引用触发器中发生变化的记录内容,这与其他的数据库是相似的。现在触发器还只支持行级触发,不支持语句级触发。

1.9K00
领券