MySQL触发器怎样使用
发布时间:2023-05-05 12:43:56 所属栏目: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','',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 (编辑:汽车网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
推荐文章
站长推荐