酷站(www.ku0.com)-致力于为互联网从业者提供动力!

热门关键词:  企业  as  baidu  c4rp3nt3r  美女
【ECS精选特惠】新用户上云低至1折起
百度资源

mysql触发器简介、创建触发器及使用限制的介绍

来源:互联网搜集 作者:秩名 人气: 发布时间:2019-12-16
本篇文章主要介绍了mysql触发器简介、创建触发器及使用限制的介绍,对大家的学习或者工作具有一定的参考学习价值,感兴趣的小伙伴们可以参考一下,也感谢大家对酷站(ku0.com)的支持。

简介
 

SQL触发器是存储在数据库目录中的一组SQL语句。每当与表相关联的事件发生时,即会执行或触发SQL触发器,例如插入,更新或删除。SQL触发器也可以当做是一种特殊类型的存储过程。 它是特别的,因为它不像直接像存储过程那样调用。 触发器和存储过程之间的主要区别在于,当对表执行数据修改事件时,会自动调用触发器,而存储过程必须要明确地调用。


完事我们来看下SQL触发器的优点:
 

  • SQL触发器提供了检查数据完整性的替代方法。
  • SQL触发器可以捕获数据库层中业务逻辑中的错误。
  • SQL触发器提供了运行计划任务的另一种方法。通过使用SQL触发器,您不必等待运行计划的任务,因为在对表中的数据进行更改之前或之后自动调用触发器。
  • SQL触发器对于审核表中数据的更改非常有用。


再来看下它的缺点:
 

  • SQL触发器只能提供扩展验证,并且无法替换所有验证。一些简单的验证必须在应用层完成。 例如,您可以使用JavaScript或服务器端使用服务器端脚本语言(如JSP,PHP,ASP.NET,Perl等)来验证客户端的用户输入。
  • 从客户端应用程序调用和执行SQL触发器不可见,因此很难弄清数据库层中发生的情况。
  • SQL触发器可能会增加数据库服务器的开销。


既然触发器都是一种特殊的存储过程了,那么我们在它们中间该如何取舍呢?在下只是建议下,如果我们无法使用存储过程完成工作时,可以考虑使用下SQL触发器。

创建触发器

在MySQL中,触发器是一组SQL语句,当对相关联的表上的数据进行更改时,会自动调用该语句。 触发器可以被定义为在insert,update或delete语句更改数据之前或之后调用。在MySQL5.7.2版本之前,每个表最多可以定义六个触发器。我们来看下它们的简单介绍:
 

  • BEFORE INSERT - 在数据插入表之前被激活触发器。
  • AFTER INSERT - 在将数据插入表之后激活触发器。
  • BEFORE UPDATE - 在表中的数据更新之前激活触发器。
  • AFTER UPDATE - 在表中的数据更新之后激活触发器。
  • BEFORE DELETE - 在从表中删除数据之前激活触发器。
  • AFTER DELETE - 从表中删除数据之后激活触发器。


但是,从MySQL 5.7.2+版本开始,可以为相同的触发事件和动作时间定义多个触发器。当使用不使用INSERT,DELETE或UPDATE语句更改表中数据的语句时,不会调用与表关联的触发器。

例如,truncate语句删除表的所有数据,但不调用与该表相关联的触发器。但是,有些语句使用了后台的INSERT语句,如REPLACE语句或LOAD DATA语句。如果使用这些语句,则调用与表关联的相应触发器。所以我们必须要为与表相关联的每个触发器使用唯一的名称。可以为不同的表定义相同的触发器名称,这是一个很好的做法。我们来看下定义触发器的语法结构:

 

 
BEFORE | AFTER)_tableName_(INSERT| UPDATE | DELETE)

例如,before_order_update是更新orders表中的行数据之前调用的触发器。我们再来看一种定义方式:

 
tablename_(BEFORE | AFTER)_(INSERT| UPDATE | DELETE)

例如,order_before_update与上述before_order_update触发器相同。

mysql会在在数据目录中存储触发器,例如:/data/luyaran/,并使用名为tablename.TRG和triggername.TRN的文件:

  • tablename.TRG文件将触发器映射到相应的表。
  • triggername.TRN文件包含触发器定义。


所以我们可以通过将触发器文件复制到备份文件夹来备份mysql触发器,还可以使用mysqldump工具备份触发器。

使用限制

mysql触发器覆盖标准SQL中定义的所有功能,但是,在应用程序中使用它们也会有一些限制:
 

  • 使用在SHOW,LOAD DATA,LOAD TABLE,BACKUP DATABASE,RESTORE,FLUSH和RETURN语句之上。
  • 使用隐式或明确提交或回滚的语句,如COMMIT,ROLLBACK,START TRANSACTION,LOCK/UNLOCK TABLES,ALTER,CREATE,DROP,RENAME等。
  • 使用准备语句,如PREPARE,EXECUTE等
  • 使用动态SQL语句。


好啦,本次记录就到这里了。

版权声明:本文内容来源于互联网或用户自行发布贡献,该文观点仅代表原作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 959677720#qq.cn(#换@) 举报,一经查实,本站将立刻删除。
原文链接:https://blog.csdn.net/luyaran/article/details/81027350

相关文章

  • MySQL explain获取查询指令信息原理介绍

    MySQL explain获取查询指令信息原理介绍

    explain用于获取查询执行计划信息, 一、语法 只需要在select前加上explain即可,如: mysql explain select 1;+----+-------------+-------+------------+------+---------------+------+---------+------+------+----------+----------......
    05-15
  • mysql查询每小时数据和上小时数据的差值的实现方法

    mysql查询每小时数据和上小时数据的差值的实现方法

    一、前言 需求是获取某个时间范围内每小时数据和上小时数据的差值以及比率。本来以为会是一个很简单的 sql ,结果思考两分钟发现并不简单,网上也没找到参考的方案,那就只能自己慢慢分析了。 刚开始没思路,就去问 DBA 同学,结果 DBA ......
    04-25
  • mysql条件查询and or使用方法及优先级

    mysql条件查询and or使用方法及优先级

    mysql and与or介绍 AND 和 OR 可在 WHERE 子语句中把两个或多个条件结合起来。 使用OR关键字时: 只要符合这几个查询条件的其中一个条件,这样的记录就会被查询出来。 如果不符合这些查询条件中的任何一条,这样的记录将被排除掉。 使用a......
    04-23
  • MySQL表中非主键列溢出情况监控的介绍

    MySQL表中非主键列溢出情况监控的介绍

    这次遇到的坑,更加的隐蔽。 是一个log表里面的一个int signed类型的列写满了。快速的解决方法当然还是只能切新表来救急了,然后搬迁老表的部分历史数据到热表。 亡羊补牢,处理完故障后,赶紧写脚本把生产的其他表都捋一遍。 下面是我暂......
    04-20
  • MySQL表自增id溢出的故障复盘解决的方法

    MySQL表自增id溢出的故障复盘解决的方法

    问题:MySQL某个表自增id溢出导致某业务block 背景: tokudb引擎的一个大表tb1,存放业务上的机审日志,每天有大量的写入, 并且由于历史原因,这张表是int signed 类型的,最大只能存 2147483647行记录 。 处理过程: 增加DBLE中间件代......
    04-17
  • mysql外键基本功能与用法的介绍

    mysql外键基本功能与用法的介绍

    本文内容: 什么是外键 外键的增加 外键的修改和删除 外键的约束模式 首发日期:2018-04-12 什么是外键: 外键就是表中存在一个 字段 指向 另外一个表的主键 ,那么这个字段就可以称为外键。 一张表可以有多个外键。 外键用于约束表与表......
    04-15
  • mysql语句书写和执行顺序的介绍

    mysql语句书写和执行顺序的介绍

    mysql语句的书写顺序和执行顺序有很大差异。 书写顺序,mysql的一般书写顺写为: select 要返回的数据列 from 表名 join, left join, right join... join join表 on join条件 where where条件 group by 分组条件 having 分组后的筛选条件......
    03-27
  • 详解MySQL union all与union的区别

    详解MySQL union all与union的区别

    union 是对数据进行并集操作,不包括重复行,同时进行默认排序Union all 是对数据进行并集操作,包括重复行,不进行排序举例说明: 创建数据库表: ? 1 2 3 4 5 6 7 CREATE TABLE `t_demo` ( `id` int (32) NOT NULL , ` name ` varchar ......
    03-26
  • MySQL case when使用方法的介绍

    MySQL case when使用方法的介绍

    首先我们创建数据库表: CREATE TABLE `t_demo` ( `id` int(32) NOT NULL, `name` varchar(255) DEFAULT NULL, `age` int(2) DEFAULT NULL, `num` int(3) DEFAULT NULL, PRIMARY KEY (`id`)) ENGINE=InnoDB DEFAULT CHARSET=utf8; 插入数......
    03-26
  • SQL注入漏洞过程实例及解决方案

    SQL注入漏洞过程实例及解决方案

    代码示例: public class JDBCDemo3 { public static void demo3_1(){ boolean flag=login(aaa OR ,1651561); //若已知用户名,用这种方式便可不用知道密码就可登陆成功 if (flag){ System.out.println(登陆成功); }else{ System.out.pri......
    03-21

最新更新