返回顶部
首页 > 资讯 > 数据库 >MySql数据库触发器如何使用
  • 694
分享到

MySql数据库触发器如何使用

2023-06-30 17:06:11 694人浏览 泡泡鱼
摘要

这篇文章主要讲解了“MySql数据库触发器如何使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Mysql数据库触发器如何使用”吧!一、介绍触发器是一种特殊的存储过程。触发器和存储过程一样,

这篇文章主要讲解了“MySql数据库触发器如何使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Mysql数据库触发器如何使用”吧!

    一、介绍

    触发器是一种特殊的存储过程。触发器和存储过程一样,是一个能够完成特定功能、存储在数据库服务器上的sql片段,但是触发器无语调用,当对数据库表中的数据执行DML操作时自动触发这个SQL片段的执行,无需手动调用。

    mysql中,只有执行insert,delete,update操作时才能触发触发器的执行

    触发器的这种特性可以协助应用在数据库端确保数据的完整性,日志记录,数据校验等操作

    使用别名OLD和NEW来引用触发器中发生变化的记录内容,这与其他的数据库是相似的,现在触发器只支持行级触发,不支持语句级触发

    二、操作

    1、表数据准备

    # 用户表SET NAMES utf8mb4;SET FOREIGN_KEY_CHECKS = 0;-- ------------------------------ Table structure for users-- ----------------------------DROP TABLE IF EXISTS `users`;CREATE TABLE `users`  (  `id` int(10) NOT NULL AUTO_INCREMENT COMMENT '主键',  `user_name` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci DEFAULT NULL COMMENT '用户名',  `sex` varchar(1) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci DEFAULT NULL COMMENT '性别',  PRIMARY KEY (`id`) USING BTREE) ENGINE = InnoDB AUTO_INCREMENT = 5 CHARACTER SET = utf8mb4 COLLATE = utf8mb4_general_ci ROW_FORMAT = Dynamic;SET FOREIGN_KEY_CHECKS = 1;# 用户操作日志表SET NAMES utf8mb4;SET FOREIGN_KEY_CHECKS = 0;-- ------------------------------ Table structure for user_log-- ----------------------------DROP TABLE IF EXISTS `user_log`;CREATE TABLE `user_log`  (  `id` int(11) NOT NULL AUTO_INCREMENT,  `content` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci DEFAULT NULL,  `create_time` datetime(0) DEFAULT NULL,  PRIMARY KEY (`id`) USING BTREE) ENGINE = InnoDB AUTO_INCREMENT = 1 CHARACTER SET = utf8mb4 COLLATE = utf8mb4_general_ci ROW_FORMAT = Dynamic;SET FOREIGN_KEY_CHECKS = 1;

    2、触发器格式

    # 创建只有一个执行语句的触发器create trigger 触发器名 before|after 触发事件on 表名 for each row执行语句;# 创建有多个执行语句的触发器create trigger 触发器名 before|after 触发事件on 表名 for each rowbegin     执行语句列表end;

    3、操作

    drop TRIGGER if EXISTS TRIGGER_test;-- 需求1:当users表添加一行数据,则会自动在user_log添加日志记录delimiter $$CREATE TRIGGER TRIGGER_test after INSERTon users FOR EACH ROWBEGININSERT INTO user_log(content,create_time) VALUES('添加了一条数据',NOW());end $$delimiter ;INSERT INTO users(user_name,sex) VALUES('xiaohemaio','男');-- 需求2:当users表修改一行数据,则会自动在user_log添加日志记录drop TRIGGER if EXISTS TRIGGER_test1;delimiter $$CREATE TRIGGER TRIGGER_test1  BEFORE UPDATEon users FOR EACH ROWBEGININSERT INTO user_log(content,create_time) VALUES('修改了一条数据',NOW());end $$delimiter ;update users set user_name='迪丽热巴' WHERE id=3;

    三、触发器NEW和OLD的使用

    MySql中定义了NEW和OLD,用来表示触发器的所在表中,触发了触发器的那一行数据,来引用触发器中发生变化的记录内容。

    MySql数据库触发器如何使用

    使用方法:NEW.columnName (columnName为相应数据表某一列名)

    1、案例

    -- 案例一drop TRIGGER if EXISTS TRIGGER_test2;delimiter $$CREATE TRIGGER TRIGGER_test2 after INSERTon users FOR EACH ROWBEGININSERT INTO user_log(content,create_time) VALUES(CONCAT('添加的用户信息为:',NEW.user_name,' 性别为:',NEW.sex ),NOW());end $$delimiter ;INSERT INTO users(user_name,sex) VALUES('xiaohemaio','男');-- 案例二 drop TRIGGER if EXISTS TRIGGER_test3;delimiter $$CREATE TRIGGER TRIGGER_test3  BEFORE UPDATEon users FOR EACH ROWBEGININSERT INTO user_log(content,create_time) VALUES(CONCAT('将:',OLD.user_name,' 修改为:',NEW.user_name ),NOW());end $$delimiter ;update users set user_name='迪丽热巴' WHERE id=4;-- 案例三drop TRIGGER if EXISTS TRIGGER_test4;delimiter $$CREATE TRIGGER TRIGGER_test4  BEFORE DELETEon users FOR EACH ROWBEGININSERT INTO user_log(content,create_time) VALUES(CONCAT('将id为:',OLD.user_name,' 已删除' ),NOW());end $$delimiter ;DELETE FROM  users WHERE id=4;

    MySql数据库触发器如何使用

    四、其他操作

    -- 查看触发器SHOW TRIGGERS;-- 删除触发器drop TRIGGER if EXISTS 触发器名;

    五、注意事项

    触发器中不能对本表进行insert,update,delete操作,以免递归循环触发

    尽量少使用 触发器,假设触发器触发每次执行1s,insert table 500条数据,那么就需要触发500次触发器,光是触发器执行的时间就花费了500s,而insert 500条数据一共是1s,那么这个insert 的效率就非常低了。

    触发器是针对每一行的数据,对增删改非常频繁的表上切记不要使用触发器,因为非常消耗资源。

    补充:验证触发器

    向用户表users插入数据。

    mysql> INSERT INTO users (userName, passWord, name, nickName, sex, email, isManager) VALUE ('itbilu', 'e10adc3949ba59abbe56e057f20f883e', 'IT笔录', 'itbilu', 1, 'cn.liuht@gmail.com', 0);

    users原来没有数据,刚插入的数据userId为1。向用户表角色表userRoles插入数据,使触发器触发:

    mysql> INSERT INTO userRoles (userId, roleId) VALUE (1, 1);

    刚才插入的数据已经使触发器触发,查看结果如下:

    mysql> select isManager from users;+-----------+| isManager |+-----------+|         1 |+-----------+

    感谢各位的阅读,以上就是“MySql数据库触发器如何使用”的内容了,经过本文的学习后,相信大家对MySql数据库触发器如何使用这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

    您可能感兴趣的文档:

    --结束END--

    本文标题: MySql数据库触发器如何使用

    本文链接: https://lsjlt.com/news/330528.html(转载时请注明来源链接)

    有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

    猜你喜欢
    • MySql数据库触发器如何使用
      这篇文章主要讲解了“MySql数据库触发器如何使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“MySql数据库触发器如何使用”吧!一、介绍触发器是一种特殊的存储过程。触发器和存储过程一样,...
      99+
      2023-06-30
    • 如何使用数据库触发器
      这篇文章主要介绍“如何使用数据库触发器”,在日常操作中,相信很多人在如何使用数据库触发器问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”如何使用数据库触发器”的疑惑有所帮助!接...
      99+
      2024-04-02
    • MySQL数据库的触发器的使用
      目录使用触发器触发器创建触发器删除触发器使用触发器INSERT触发器DELETE触发器UPDATE触发器触发器的进一步介绍使用触发器 触发器 发生什么事情之后或之前,会自动执行某条语句,这就是触发器 创建触发器 创建触发...
      99+
      2024-04-02
    • MySql数据库触发器使用教程
      目录一、介绍二、操作1、表数据准备2、触发器格式3、操作三、触发器NEW和OLD的使用1、案例四、其他操作五、注意事项补充:验证触发器总结一、介绍 1、触发器是一种特殊的存储过程。触...
      99+
      2024-04-02
    • MySQL数据库触发器trigger怎么使用
      这篇文章主要讲解了“MySQL数据库触发器trigger怎么使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“MySQL数据库触发器trigger怎么使用”吧!一、基本概念触发器是一种特殊类...
      99+
      2023-07-02
    • 如何删除mysql数据库的触发器
      小编给大家分享一下如何删除mysql数据库的触发器,希望大家阅读完这篇文章后大所收获,下面让我们一起去探讨吧!在mysql中,可以使用“DROP TRIGGER”语句来删除已经定义的触发器,语法格式...
      99+
      2024-04-02
    • MySQL数据库 触发器 trigger
      目录一、基本概念1、作用2、触发器的优缺点2.1、优点2.2、缺点二、创建触发器1、基本语法2、触发对象3、触发时机4、触发事件5、注意事项三、查看触发器四、触发触发器五、删除触发器六、触发器的应用1、完善2、优化一、基...
      99+
      2022-06-16
      MySQL trigger 触发器trigger
    • MYSQL数据库触发器怎么用
      今天小编给大家分享一下MYSQL数据库触发器怎么用的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一...
      99+
      2024-04-02
    • 如何使用mysql触发器
      小编这次要给大家分享的是如何使用mysql触发器,文章内容丰富,感兴趣的小伙伴可以来了解一下,希望大家阅读完这篇文章之后能够有所收获。例子:创建触发器,记录表的增、删、改操作记录//创建user表; DRO...
      99+
      2024-04-02
    • MySQL触发器如何使用
      本文小编为大家详细介绍“MySQL触发器如何使用”,内容详细,步骤清晰,细节处理妥当,希望这篇“MySQL触发器如何使用”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。MySQL—触发器将两个关...
      99+
      2023-07-05
    • sql数据库触发器如何写
      编写SQL数据库触发器可以使用以下语法: CREATE TRIGGER trigger_name {BEFORE | AFTER} ...
      99+
      2023-10-24
      sql数据库
    • 数据库:触发器
      触发器的概念:    是用户定义在关系表上的一类有事件驱动的特殊过程。一旦定义,任何对表的增删改操作均有服务器自动激活相应的触发器,在DBMS核心层进行集中的完整性控...
      99+
      2024-04-02
    • 数据库-触发器
      目录 1. 触发器概述 2. 触发器的创建 2.1 创建触发器语法 3. 查看、删除触发器  3.2 删除触发器 4. 触发器的优缺点 4.2 缺点 4.3 注意点 在实际开发中,我们经常会遇到这样的情况:有 2 个或者多个相互关联的表...
      99+
      2023-09-22
      数据库 mysql
    • 详解MySQL数据库之触发器
      1 引言 本文是对MySQL中触发器的总结,从触发器概念出发,结合实例对创建触发器、使用触发器、删除触发器进行介绍。 2 触发器简介 MySQL触发器和存储过程一样,都是嵌入到MySQL的一段程序。触发器是由事件...
      99+
      2022-05-20
      MySQL 触发器
    • MySQL数据库高级(五)——触发器
      MySQL数据库高级(五)——触发器 一、触发器简介 1、触发器简介 触发器是和表关联的特殊的存储过程,可以在插入,删除或修改表中的数据时触发执行,比数据库本身标准的功能有更精细和更复杂的数据控制能力。 2...
      99+
      2024-04-02
    • MySQL数据库提升篇-----触发器
      day06 MySQL数据库提升篇-----触发器一、触发器概述:    触发器是什么?能有什么作用?能给我们带来什么样的操作数据库的方法这都在这里学一一的告诉大家。...
      99+
      2024-04-02
    • 如何在MySQL触发器中使用参数
      如何在MySQL触发器中使用参数,需要具体代码示例 MySQL是一种流行的关系型数据库管理系统,它支持触发器来监控表中数据的变化并执行相应的操作。触发器可以在INSERT、UPDATE...
      99+
      2024-04-02
    • MySQL数据库——MySQL创建触发器(CREATE TRIGGER)
      触发器是与 MySQL 数据表有关的数据库对象,在满足定义条件时触发,并执行触发器中定义的语句集合。触发器的这种特性可以协助应用在数据库端确保数据的完整性。 基本语法 在 MySQL 5.7 中,可以使用 CREATE TRIGGER 语句...
      99+
      2023-10-20
      数据库 mysql java
    • 数据库中触发器的使用方法
      本篇文章给大家分享的是有关数据库中触发器的使用方法,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。创建数据库触发器的语法是:【CREATE &l...
      99+
      2024-04-02
    • 数据库触发器的作用
      这篇文章主要介绍数据库触发器的作用,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!数据库中的触发器的作用:触发器主要用于强制复杂的业务规则和要求,还有助于强制引用的完整性,便于在添加,...
      99+
      2024-04-02
    软考高级职称资格查询
    编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
    • 官方手机版

    • 微信公众号

    • 商务合作