MySQL触发器如何使用

数据库   发布日期:2023年07月22日   浏览次数:505

本文小编为大家详细介绍“MySQL触发器如何使用”,内容详细,步骤清晰,细节处理妥当,希望这篇“MySQL触发器如何使用”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。

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结构组成的复合语句块。

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

查看触发器

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

  1. mysql> SHOW TRIGGERSG;
  2. *************************** 1. row ***************************
  3. Trigger: salary_check_trigger
  4. Event: INSERT
  5. Table: emp
  6. Statement: BEGIN
  7. DECLARE mgr_sal DOUBLE;
  8. SELECT salary INTO mgr_sal FROM emp
  9. WHERE employee_id = NEW.manager_id;
  10. IF NEW.salary > mgr_sal
  11. THEN SIGNAL SQLSTATE 'HY000' SET MESSAGE_TEXT = '薪资不得高于领导薪资';
  12. END IF;
  13. END
  14. Timing: BEFORE
  15. Created: 2023-02-28 15:46:44.71
  16. 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
  17. Definer: root@%
  18. character_set_client: utf8
  19. collation_connection: utf8_general_ci
  20. Database Collation: utf8_general_ci

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

  1. SHOW CREATE TRIGGER salary_check_triggerG;

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

  1. SELECT * FROM information_schema.TRIGGERSG;

删除触发器

  1. DROP TRIGGER salary_check_trigger

触发器优缺点

优点:

  • 可以确保数据的完整性

  • 可以帮助记录操作日志

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

缺点:

  • 可读性差

  • ER salary_check_trigger

### 触发器优缺点

#### 优点:

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

#### 缺点:

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

以上就是MySQL触发器如何使用的详细内容,更多关于MySQL触发器如何使用的资料请关注九品源码其它相关文章!