MySQL 触发器定义与用法简单实例

 更新时间:2019年09月02日 11:30:03   作者:yqwang75457  
这篇文章主要介绍了MySQL 触发器定义与用法,结合简单实例形式总结分析了mysql触发器的语法、原理、定义及使用方法,需要的朋友可以参考下

本文实例讲述了MySQL 触发器定义与用法。分享给大家供大家参考,具体如下:

语法

CREATE TRIGGER 触发器名称  --触发器必须有名字,最多64个字符,可能后面会附有分隔符.它和MySQL中其他对象的命名方式基本相象.
{ BEFORE | AFTER }  --触发器有执行的时间设置:可以设置为事件发生前或后。
{ INSERT | UPDATE | DELETE }  --同样也能设定触发的事件:它们可以在执行insert、update或delete的过程中触发。
ON 表名称  --触发器是属于某一个表的:当在这个表上执行插入、 更新或删除操作的时候就导致触发器的激活. 我们不能给同一张表的同一个事件安排两个触发器。
FOR EACH ROW  --触发器的执行间隔:FOR EACH ROW子句通知触发器 每隔一行执行一次动作,而不是对整个表执行一次。
<触发器SQL语句>  --触发器包含所要触发的SQL语句:这里的语句可以是任何合法的语句, 包括复合语句,但是这里的语句受的限制和函数的一样。

实例准备工作

-- 创建表tab1
DROP TABLE IF EXISTS tab1;
CREATE TABLE tab1(
  tab1_id varchar(11)
);
-- 创建表tab2
DROP TABLE IF EXISTS tab2;
CREATE TABLE tab2(
  tab2_id varchar(11)
);

实例1:新增一条,触发另外一张表的新增

-- 创建触发器:t_afterinsert_on_tab1
-- 作用:增加tab1表记录后自动将记录增加到tab2表中
DROP TRIGGER IF EXISTS t_afterinsert_on_tab1;
CREATE TRIGGER t_afterinsert_on_tab1
AFTER INSERT ON tab1
FOR EACH ROW
BEGIN
   insert into tab2(tab2_id) values(new.tab1_id);
END;
-- 测试一下
INSERT INTO tab1(tab1_id) values('0001');
-- 看看结果
SELECT * FROM tab1;
SELECT * FROM tab2

实例2:删除一条,触发另外一张表的删除

-- 创建触发器:t_afterdelete_on_tab1
-- 作用:删除tab1表记录后自动将tab2表中对应的记录删去
DROP TRIGGER IF EXISTS t_afterdelete_on_tab1;
CREATE TRIGGER t_afterdelete_on_tab1
AFTER DELETE ON tab1
FOR EACH ROW
BEGIN
   delete from tab2 where tab2_id=old.tab1_id;
END;
-- 测试一下
DELETE FROM tab1 WHERE tab1_id='0001';
-- 看看结果
SELECT * FROM tab1;
SELECT * FROM tab2;

实例3:更新一条,触发另外一张表的更新

-- 创建触发器:t_afterupdate_on_tab1
-- 作用:修改tab1表记录后自动将tab2表中对应的记录更新
DROP TRIGGER IF EXISTS t_afterupdate_on_tab1;
CREATE TRIGGER t_afterupdate_on_tab1
AFTER UPDATE ON tab1
FOR EACH ROW
BEGIN
   update tab2 set tab2_id=new.tab1_id where tab2_id=old.tab1_id;
END;
-- 测试一下
update tab1 set tab1_id='0002' WHERE tab1_id='0001';
-- 看看结果
SELECT * FROM tab1;
SELECT * FROM tab2;

更多关于MySQL相关内容感兴趣的读者可查看本站专题:《MySQL查询技巧大全》、《MySQL事务操作技巧汇总》、《MySQL存储过程技巧大全》、《MySQL数据库锁相关技巧汇总》及《MySQL常用函数大汇总

希望本文所述对大家MySQL数据库计有所帮助。

相关文章

  • MYSQL updatexml()函数报错注入解析

    MYSQL updatexml()函数报错注入解析

    这篇文章主要介绍了MYSQL updatexml()函数报错注入解析,并且简单介绍了updatexml函数,具有一定参考价值,需要的朋友可以了解下。
    2017-10-10
  • mysql数据库单表最大存储依据详解

    mysql数据库单表最大存储依据详解

    这篇文章主要为大家介绍了mysql数据库单表最大存储的依据详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-07-07
  • MYSQL主从不同步延迟原理分析及解决方案

    MYSQL主从不同步延迟原理分析及解决方案

    这篇文章介绍了MYSQL主从不同步延迟原理分析及解决方案,有需要的朋友可以参考一下
    2013-09-09
  • mysql随机抽取一定数量的记录实例讲解

    mysql随机抽取一定数量的记录实例讲解

    在本篇文章里小编给大家整理的是关于mysql随机抽取一定数量的记录实例相关知识点,有需要的朋友们可以学习下。
    2019-09-09
  • MySQL中数据查询语句整理大全

    MySQL中数据查询语句整理大全

    查询语句是以后在工作中使用最多也是最复杂的用法,如何精准的查询出想要的结果以及用最合理的逻辑去查询尤为重要,下面这篇文章主要给大家介绍了关于MySQL中数据查询语句的相关资料,需要的朋友可以参考下
    2023-04-04
  • 关于MySQL报警的一次分析处理详解

    关于MySQL报警的一次分析处理详解

    这篇文章主要给大家介绍了关于MySQL报警的一次分析处理的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-03-03
  • Mysql Sql 语句练习题(50道)

    Mysql Sql 语句练习题(50道)

    mysql一直作为比较热门的数据库存储,搭配php使用简直是绝配,mysql的sql语句也是很重要的一门课,这里为大家分享一下sql语句,大家可以试试
    2020-12-12
  • python中的mysql数据库LIKE操作符详解

    python中的mysql数据库LIKE操作符详解

    LIKE操作符用于在WHERE子句中搜索列中的指定模式,like操作符的语法在文章开头也给大家提到,通过两种示例代码给大家介绍python中的mysql数据库LIKE操作符知识,感兴趣的朋友跟随小编一起看看吧
    2021-07-07
  • MySQL查询重写插件的使用

    MySQL查询重写插件的使用

    这篇文章主要介绍了MySQL查询重写插件的使用,帮助大家更好的理解和维护数据库,感兴趣的朋友可以了解下
    2020-11-11
  • MySQL中的多字段相同数据去重复

    MySQL中的多字段相同数据去重复

    这篇文章主要介绍了MySQL中的多字段相同数据去重复问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-12-12

最新评论