MySQL触发器使用过程详解

作者:瀛台夜雪 时间:2024-01-28 08:22:55 

MySQL—触发器

将两个关联的操作步骤写到程序里面,并且要用事务包裹起来,确保两个操作称为一个原子操作,要么全部执行,要么全部不执行

创建一个触发器,让商品信息数据的插入操作自动触发库存数据的插入操作

触发器是由 事件来触发 某个操作,这些事件包括 INSERT 、 UPDATE 、 DELETE 事件。所谓事件就是指用户的动作或者触发某项行为。如果定义了触发程序,当数据库执行这些语句时候,就相当于事件发生 了,就会 自动 激发触发器执行相应的操作。

创建触发器

CREATE TRIGGER 触发器名称
{BEFORE|AFTER} {INSERT|UPDATE|DELETE} ON 表明
FOR EACH ROW
触发器执行语句

说明:

表名 :表示触发器监控的对象。

BEFORE|AFTER :表示触发的时间。BEFORE 表示在事件之前触发;AFTER 表示在事件之后触发。

INSERT|UPDATE|DELETE :表示触发的事件。

  • INSERT 表示插入记录时触发;

  • UPDATE 表示更新记录时触发;

  • DELETE 表示删除记录时触发。

触发器执行的语句块 :可以是单条SQL语句,也可以是由BEGIN…END结构组成的复合语句块。

DELIMITER //
CREATE TRIGGER before_insert_test_tri
BEFORE INSERT ON test_trigger
FOR EACH ROW
BEGIN
INSERT INTO test_trigger_log(t_node)
VALUES('before insert');
END //
DELIMITER ;
INSERT INTO test_trigger(t_node)
VALUES('test..');
SELECT * FROM test_trigger;
SELECT * FROM test_trigger_log;
DELIMITER //
CREATE TRIGGER salary_check_trigger
BEFORE INSERT ON emp
FOR EACH ROW
BEGIN
DECLARE mgr_sal DOUBLE;
SELECT salary INTO mgr_sal FROM emp
WHERE employee_id = NEW.manager_id;
IF NEW.salary > mgr_sal
THEN SIGNAL SQLSTATE 'HY000' SET MESSAGE_TEXT = '薪资不得高于领导薪资';
END IF;
END //
DELIMITER ;
DESC emp;
INSERT INTO emp(employee_id,last_name,email,hire_date,job_id,salary,manager_id)
VALUES(300,'test','tom@126.com',CURDATE(),'AD_VP',10000,103);

查看触发器

查看当前数据库所有触发器的定义

mysql> SHOW TRIGGERS\G;
*************************** 1. row ***************************
            Trigger: salary_check_trigger
              Event: INSERT
              Table: emp
          Statement: BEGIN
DECLARE mgr_sal DOUBLE;
SELECT salary INTO mgr_sal FROM emp
WHERE employee_id = NEW.manager_id;
IF NEW.salary > mgr_sal
THEN SIGNAL SQLSTATE 'HY000' SET MESSAGE_TEXT = '薪资不得高于领导薪资';
END IF;
END
             Timing: BEFORE
            Created: 2023-02-28 15:46:44.71
           sql_mode: ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION
            Definer: root@%
character_set_client: utf8
collation_connection: utf8_general_ci
 Database Collation: utf8_general_ci

查看当前数据库中某个触发器的定义

SHOW CREATE TRIGGER salary_check_trigger\G;

从系统库information_schema的TRIGGERS表中查询“salary_check_trigger”触发器的信息。

SELECT * FROM information_schema.TRIGGERS\G;

删除触发器

DROP TRIGGER salary_check_trigger

触发器优缺点

优点:

  • 可以确保数据的完整性

  • 可以帮助记录操作日志

  • 可以用在操作数据前,对数据进行合法性检验

缺点:

  • 可读性差

  • ER salary_check_trigger

### 触发器优缺点

#### 优点:

- 可以确保数据的完整性
- 可以帮助记录操作日志
- 可以用在操作数据前,对数据进行合法性检验

#### 缺点:

- 可读性差
- 相关数据的变更,可能会导致触发器错误

来源:https://blog.csdn.net/sxycylq/article/details/129264009

标签:MySQL,触发器
0
投稿

猜你喜欢

  • Django实现分页功能

    2023-04-04 11:00:56
  • asp 在线备份与恢复sqlserver数据库的代码

    2011-03-06 11:14:00
  • pycharm开发一个简单界面和通用mvc模板(操作方法图解)

    2022-10-09 06:28:39
  • 详解如何使用beego orm在postgres中存储图片

    2024-04-25 15:14:46
  • PyTorch中torch.utils.data.DataLoader简单介绍与使用方法

    2023-10-30 07:12:00
  • python字典添加值的方法及实例代码分享

    2023-04-22 09:58:13
  • Python 深入理解yield

    2021-05-09 06:37:23
  • Vue 实现穿梭框功能的详细代码

    2024-05-09 10:51:53
  • Python OpenCV之图片缩放的实现(cv2.resize)

    2023-01-08 14:02:48
  • 在ASP中使用SQL语句之6:存储过程查询

    2007-08-11 12:44:00
  • Python多进程并发与同步机制超详细讲解

    2022-11-22 08:35:02
  • pyhton学习与数据挖掘self原理及应用分析

    2023-07-04 23:19:11
  • python中split()函数的用法详解

    2022-01-13 14:52:06
  • 使用Python matplotlib绘制简单的柱形图、折线图和直线图

    2022-04-08 02:13:19
  • 详解Vue.js——60分钟组件快速入门(上篇)

    2024-05-03 15:12:29
  • Python time模块之时间戳与结构化时间的使用

    2024-01-02 09:07:51
  • python如何运行js语句

    2022-04-10 02:34:27
  • 简单上手Python中装饰器的使用

    2023-06-20 19:20:06
  • MySQL面试题讲解之如何设置Hash索引

    2024-01-21 17:23:55
  • python数字图像处理实现图像的形变与缩放

    2023-01-14 19:45:01
  • asp之家 网络编程 m.aspxhome.com