Ein Trigger ist eine spezielle Art einer gespeicherten Prozedur. Der Trigger wird durch das Ereignis ausgelöst und ausgeführt 🎜#Erzwingen Sie vor dem Schreiben in die Datentabelle die Überprüfung oder Konvertierung der Daten (um die Datensicherheit zu gewährleisten)
Einige Datenbankverwaltungssysteme können Trigger für die Datendefinitionssprache DDL verwenden, sogenannte DDL-Trigger
#🎜 🎜#2.1 , Vorteile
Trigger können kaskadierende Änderungen durch verwandte Tabellen in der Datenbank erreichen (wenn sich die Daten einer Tabelle ändern, können Trigger verwendet werden, um Operationen auf anderen zu implementieren Tabellen, der Benutzer weiß es nicht)
#🎜🎜 # Daten sind auf Programmebene nicht kontrollierbar
create trigger 触发器名字 触发时机 触发事件 on 表 for each row begin end
2 . Triggerobjekt
auf Tabelle für jede Zeile
Der Trigger bindet alle Zeilen in der Tabelle, wenn eine beliebige Zeile eine bestimmte Änderung aufweist, wird der Trigger ausgelöston 表 for each row
触发器绑定表中所有行,没一行发生指定改变的时候,就会触发触发器
每张表对应的行都有不同的状态,当SQL指令发生的时候,都会令行中数据发生改变,每一行总会有两种状态:数据操作前和数据操作后
before: 数据发生改变前的状态
after: 数据已经发生改变后的状态
mysql中触发器针对的目标是数据发生改变,对应的操作只有写操作(增删改)
inert 插入操作
update 更新操作
delete 删除操作
一张表中,每一个触发时机绑定的触发事件对应的触发器类型只能有一个
一张表表中只能有一个对应的after insert 触发器
最多只能有6个触发器
before insert after insert before update after update before delete after delete
下单减库存
有两张表,一张是商品表,一张是订单表(保留商品ID)每次订单生成,商品表中对应的库存就应该发生变化
创建两张表:
create table my_item( id int primary key auto_increment, name varchar(20) not null, count int not null default 0 ) comment '商品表'; create table my_order( id int primary key auto_increment, item_id int not null, count int not null default 1 ) comment '订单表'; insert my_item (name, count) values ('手机', 100),('电脑', 100), ('包包', 100); mysql> select * from my_item; +----+--------+-------+ | id | name | count | +----+--------+-------+ | 1 | 手机 | 100 | | 2 | 电脑 | 100 | | 3 | 包包 | 100 | +----+--------+-------+ 3 rows in set (0.00 sec) mysql> select * from my_order; Empty set (0.02 sec)
创建触发器:
如果订单表发生数据插入,对应的商品就应该减少库存
delimiter $$ create trigger after_insert_order_trigger after insert on my_order for each row begin -- 更新商品库存 update my_item set count = count - 1 where id = 1; end $$ delimiter ;
-- 查看所有触发器 show triggers\G *************************** 1. row *************************** Trigger: after_insert_order_trigger Event: INSERT Table: my_order Statement: begin update my_item set count = count - 1 where id = 1; end Timing: AFTER Created: 2022-04-16 10:00:19.09 sql_mode: ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION Definer: root@localhost character_set_client: utf8mb4 collation_connection: utf8mb4_general_ci Database Collation: utf8mb4_general_ci 1 row in set (0.00 sec) -- 查看创建语句 show crate trigger 触发器名字; -- eg: show create trigger after_insert_order_trigger;
让触发器执行,让触发器指定的表中,对应的时机发生对应的操作
insert into my_order (item_id, count) values(1, 1); mysql> select * from my_order; +----+---------+-------+ | id | item_id | count | +----+---------+-------+ | 1 | 1 | 1 | +----+---------+-------+ 1 row in set (0.00 sec) mysql> select * from my_item; +----+--------+-------+ | id | name | count | +----+--------+-------+ | 1 | 手机 | 99 | | 2 | 电脑 | 100 | | 3 | 包包 | 100 | +----+--------+-------+ 3 rows in set (0.00 sec)
drop trigger 触发器名字; -- eg drop trigger after_insert_order_trigger;
记录关键字 new old
商品自动扣除库存
触发器针对的是数据表中的每条记录,每行数据再操作前后都有一个对应的状态
触发器在执行之前就将对应的数据状态获取到了:
将没有操作之前的数据状态都保存到old
关键字中
操作后的状态都放在new
Das Ziel des Triggers in MySQL ist die Änderung von Daten, und die entsprechende Operation ist nur eine Schreiboperation ( hinzufügen, löschen, ändern)
inert Einfügungsvorgang
update Aktualisierungsvorgang#🎜 🎜#Löschvorgang löschen
delimiter $$ create trigger after_insert_order_trigger after insert on my_order for each row begin -- 通过new关键字获取新数据的id 和数量 update my_item set count = count - new.count where id = new.item_id; end $$ delimiter ;
Nachfrage:
Auftrag zur BestandsreduzierungEs gibt zwei Tabellen, eine ist die Produkttabelle, eine ist die Bestelltabelle (unter Beibehaltung der Produkt-ID) sollte sich der entsprechende Bestand in der Produkttabelle ändern
Erstellen Sie zwei Tabellen:#🎜🎜 #
mysql> select * from my_order; +----+---------+-------+ | id | item_id | count | +----+---------+-------+ | 1 | 1 | 1 | +----+---------+-------+ mysql> select * from my_item; +----+--------+-------+ | id | name | count | +----+--------+-------+ | 1 | 手机 | 99 | | 2 | 电脑 | 100 | | 3 | 包包 | 100 | +----+--------+-------+ insert into my_order (item_id, count) values(2, 3); mysql> select * from my_order; +----+---------+-------+ | id | item_id | count | +----+---------+-------+ | 1 | 1 | 1 | | 2 | 2 | 3 | +----+---------+-------+ mysql> select * from my_item; +----+--------+-------+ | id | name | count | +----+--------+-------+ | 1 | 手机 | 99 | | 2 | 电脑 | 97 | | 3 | 包包 | 100 | +----+--------+-------+
Wenn Daten in die Bestelltabelle eingefügt werden, sollte das entsprechende Produkt im Lagerbestand reduziert werden
-- 删除原有触发器 drop trigger after_insert_order_trigger; -- 新增判断库存触发器 delimiter $$ create trigger after_insert_order_trigger after insert on my_order for each row begin -- 查询库存 select count from my_item where id = new.item_id into @count; -- 判断 if new.count > @count then -- 中断操作,暴力抛出异常 insert into xxx values ('xxx'); end if; -- 通过new关键字获取新数据的id 和数量 update my_item set count = count - new.count where id = new.item_id; end $$ delimiter ;
mysql> insert into my_order (item_id, count) values(3, 101); ERROR 1146 (42S02): Table 'mydatabase2.xxx' doesn't exist mysql> select * from my_order; +----+---------+-------+ | id | item_id | count | +----+---------+-------+ | 1 | 1 | 1 | | 2 | 2 | 3 | +----+---------+-------+ 2 rows in set (0.00 sec) mysql> select * from my_item; +----+--------+-------+ | id | name | count | +----+--------+-------+ | 1 | 手机 | 99 | | 2 | 电脑 | 97 | | 3 | 包包 | 100 | +----+--------+-------+ 3 rows in set (0.00 sec)
old
, der Status nach der Operation wird in new
platziert #🎜🎜##🎜🎜 ##🎜 🎜##🎜🎜#Im Trigger können Sie alt und neu verwenden, um die entsprechenden Datensatzdaten in der Bindungstabelle zu erhalten #🎜🎜##🎜🎜##🎜🎜#Grundlegende Syntax: #🎜🎜##🎜🎜 ## 🎜🎜##🎜🎜#Keyword.Field name#🎜🎜##🎜🎜##🎜🎜#alt und neu sind nicht für alle Trigger verfügbar #🎜🎜##🎜🎜##🎜🎜##🎜 🎜#Einfügen ist leer vor dem Einfügen, kein altes#🎜🎜##🎜🎜##🎜🎜##🎜🎜#Löschen löscht die Daten, kein neues#🎜🎜##🎜🎜##🎜🎜##🎜🎜##🎜 🎜#Item automatischer Abzug vom Lagerbestand: #🎜🎜##🎜🎜#rrreee#🎜🎜##🎜🎜# Auslöser: #🎜🎜##🎜🎜#rrreee#🎜🎜#2. Optimierung #🎜🎜## 🎜🎜##🎜 🎜#Was soll ich tun, wenn die Lagermenge nicht so groß ist wie die Produktbestellung? #🎜🎜##🎜🎜#rrreee#🎜🎜##🎜🎜#Ergebnisüberprüfung: #🎜🎜##🎜🎜#rrreee
Das obige ist der detaillierte Inhalt vonSo verwenden Sie Trigger in der MySQL-Datenbank. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!