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

MySQL数据库之触发

1 引言         本文是对MySQL触发器的总结,从触发器概念出发,结合实例对创建触发器、使用触发器、删除触发器进行介绍。...2 触发器简介 MySQL触发器和存储过程一样,都是嵌入到MySQL的一段程序。触发器是由事件来触发某个操作,这些事件包括INSERT、UPDATE、DELETE。...如果定义了触发器,当数据库执行这些语句的时候就会激活触发器执行相应的操作,触发程序是与表有关的命令数据库对象,当表上出现特定事件,将激活该对象。   ...,往tb_student表中插入一条数据(插入前3个表没有任何记录): insert into tb_student (name) values('zhangsan');   插入,查看三个表中数据:...表中查看触发器   在information_schema数据库的triggers表中存放在MySQL数据库中的所有触发器,可以通过查询语句进行查看: select * from information_schema.triggers

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

    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

    4K20

    Mysql触发

    数据库中除了需要定时完成一些任务外,有时我们也想在某些表数据变化时自动执行些操作,这就要用到触发器了 基本语法 -- 删除已有同名触发器 DROP TRIGGER IF EXISTS trigger_name...NEW.groupid and subjectid=NEW.subjectid ORDER BY examtime desc limit 0,1); END; $$ delimiter ; 定义变量 mysql...中定义了 NEW 和 OLD,用来表示触发器的所在表中,触发触发器的那一行数据。...具体: 在 INSERT 型触发器中,NEW 用来表示将要(BEFORE)或已经(AFTER)插入的新数据; 在 UPDATE 型触发器中,OLD 用来表示将要或已经被修改的原数据,NEW 用来表示将要或已经修改为的新数据...; 在 DELETE 型触发器中,OLD 用来表示将要或已经被删除的原数据; 使用方法: NEW.columnName (columnName 为相应数据表某一列名) if else declare

    4.5K30

    Mysql触发

    Mysql触发器 1.创建触发器 注意:触发器只能创建在永久表上,不能对临时表创建触发器,语法如下: CREATE TRIGGER trigger_name trigger_time trigger_event...是检查约 束触发. trigger_event:触发触发的事件,可以是insert,update或者delete....使用别名old和new来引用触发器中发生变化的记录内容,现在触发器还只支持行级触发,不支持语句级触发. 2.创建一个student表,复制一份命名为student_back: CREATE TABLE...NAME, new.age) ; END ; $$ delimiter ; 插入一条数据: INSERT INTO student(name,age) VALUES("zhansgan",15); ?...对于那些实际执行update操作的记录,仍然会执行before insert触发器的内容,在设计触发器的时候一定要考虑这种情况,避免错误地触发触发器. 4.删除触发器 drop trigger trigger_name

    5K30

    MySQL触发器)

    目录: 触发器定义 触发器特性 触发器的创建 删除触发触发器定义 与表有关的数据对象,在满足某种条件时,被动执行的SQL语句。...指定触发的频率:针对每一行的数据变化去执行SQL语句 ⑤ 触发器定义在表上 触发器的创建: 单条业务逻辑的触发器创建 语法: create trigger 触发器名称 before|after insert...|update|delete on 表名 for each row 业务逻辑; 代码实例: 当A表中插入数据,B表中也插入一条数据 create trigger trigger_insert after...insert on A for each row insert into B(comments) values('插入数据'); 详解: after:为触发器的触发时间。...new:after|before insert,用于获取将要插入的数据 old:after|before update|delete,用户获取已经修改的或已经删除的数据 删除触发器 语法: drop trigger

    12.6K10

    MySQL触发

    MySQL触发器 1.1. 定义 1.2. 创建触发器 1.2.1. 创建一行执行语句的触发器 1.2.2. 创建多行执行语句的触发器 1.3. 查看触发器 1.3.1....注意 MySQL触发器 定义 MySQL触发器和存储过程一样,都是嵌入到MysQL中的一段程序,不过触发器不要调用,而是由事件触发的,这些事件包括insert,update,delete语句,如果定义了触发程序...trigger_event:触发事件,取值为insert,update,delete insert :比如Mysql中的insert和replace语句就会触发这个事件 update:更新某一行的数据会激发这个事件...这时,若SQL语句或触发器执行失败,MySQL 会回滚事务,有: 如果 BEFORE 触发器执行失败,SQL 无法正确执行。 SQL 执行失败时,AFTER 型触发器不会触发。...; 在 DELETE型触发器中,OLD 用来表示将要或已经被删除的原数据; 使用方式 NEW/OLD.columName : 比如获取更新的name字段的值 new.name 注意 OLD 是只读的,

    5.1K20

    MySQL触发

    触发器和存储过程一样是一个能够完成特定功能、存储在数据 库服务器上的SQL片段,但是触发器无需调用,当对数据库表中的数据执行DML操作时自动触发这 个SQL片段的执行,无需手动条用。...在MySQL中,只有执行insert,delete,update操作时才能触发 触发器的执行 触发器的这种特性可以协助应用在数据库端确保数据的完整性 , 日志记录 , 数据校验 等操作 。...触发器的特性 1、什么条件会触发:I、D、U 2、什么时候触发:在增删改前或者 3、触发频率:针对每一行执行 4、触发器定义在表上,附着在表上 操作-创建触发器 格式 1、创建只有一个执行语句的触发器...' where uid = 1; 操作-NEW与OLD 格式 MySQL 中定义了 NEW 和 OLD,用来表示触发器的所在表中,触发触发器的那一行数据,来引 用触发器中发生变化的记录内容,具体地:...; 注意事项 1.MYSQL触发器中不能对本表进行 insert ,update ,delete 操作,以免递归循环触发 2.尽量少使用触发器,假设触发触发每次执行1s,insert table 500

    6.4K10

    MySQL触发

    你可以创建一个触发器,让商品信息数据的插入操作自动触发库存数 据的插入操作。这样一来,就不用担心因为忘记添加库存数据而导致的数据缺失了。...触发器概述  MySQL从 5 . 0 . 2 版本开始支持触发器。 MySQL触发器和存储过程一样,都是嵌入到MySQL服务器的一 段程序。...当对数据表中的数据执行插入、更新和删除操作,需要自动执行一些数据库逻辑时,可以使用触发器来 实现。...这些都可以通过触发器,在实际插入或者更新操作之前,对相应的数据进行检查,及时提示错误,防止 错误数据进入系统。 触发器的缺点  1、触发器最大的一个问题就是可读性差。...2、相关数据的变更,可能会导致触发器出错。 特别是数据表结构的变更,都可能会导致触发器出错,进而影响数据操作的正常运行。这些都会由于触发器本身的隐蔽性,影响到应用中错误原因排查的效率。

    3.2K20

    mysql触发

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

    6.8K30

    增加并发数,TPS增加, IOPS却下降 现象分析

    问当增加并发, tps会增加, 那系统iops是增加还是减少呢?...我第一反应是增加, 毕竟事务变多了, 写的数据肯定多了卅, 那iops肯定增加卅.如下是我测试的只写事务.环境主机: CVM 4C8G centos7.6 PAGESIZE=4096数据库: mysql...= 64M innodb_page_size=16K测试工具: sysbench 1.0.17表数据量: 10*100000注: 为了方便观察, 仅压测只写事务现象复现仅增加并发数量, 观察tps...3000图片图片80并发TPS 1500WIOPS 800 (有波动)图片图片800并发TPS 1400WIOPS 250(是不是和想象的不一样....)图片图片原因分析汇总下: 并发数增多,..., 每次刷盘是把整个innodb_log_buffer都写入redo里面(包括其它事务), 所以并发增加, 每次刷盘所包含的事务也就更多了(total次数减少), 数据量也大了(avg_written

    2.8K30
    领券