MySQL触发器

1.创建第一个触发器

sql 复制代码
mysql> delimiter //
mysql> create trigger after_insert_orders_trigger
    -> after insert on orders for each row
    -> begin
    ->      update goods set num=num-new.enum where gid=new.gid;
    -> end //
Query OK, 0 rows affected (0.00 sec)

mysql> delimiter ;

验证触发器是否能实现预期效果

sql 复制代码
mysql> insert into orders (gid,name,price,enum,otime) values ('A0001','橡皮',2.5,10,now());

向订单表插入一条购买订单后,商品表触发更新(橡皮的数量从100减到90)

2.创建第二个触发器

sql 复制代码
mysql> delimiter //
mysql> create trigger after_delete_orders_trigger
    -> after delete on orders for each row
    -> begin
    ->      update goods set num=num+old.enum where gid=old.gid;
    -> end //
Query OK, 0 rows affected (0.00 sec)

mysql> delimiter ;

验证触发器是否能实现预期效果(删除刚刚创建的订单,橡皮的库存数恢复100)

3.创建第三个触发器

sql 复制代码
mysql> delimiter //
mysql> create trigger after_update_orders_trigger
    -> after update on orders for each row
    -> begin
    ->      update goods set num=num+old.enum where gid=old.gid;
    ->      update goods set num=num-new.enum where gid=new.gid;
    -> end //
Query OK, 0 rows affected (0.01 sec)

mysql> delimiter ;

验证触发器是否能实现预期效果

sql 复制代码
插入一个订单
mysql> insert into orders (gid,name,price,enum,otime) values ('B0001','小楷
本',2.8,20,now());
Query OK, 1 row affected, 1 warning (0.00 sec)

更新订单信息
mysql> update orders set enum=100 where oid=4;
Query OK, 1 row affected (0.01 sec)
Rows matched: 1  Changed: 1  Warnings: 0
sql 复制代码
删除订单信息(小楷本的库存恢复为210)
mysql> delete from orders where oid=4;
Query OK, 1 row affected (0.01 sec)

4.创建存储过程proc001

sql 复制代码
mysql> delimiter //
mysql> create procedure proc001()
    -> begin
    ->      select name,incoming from emp_new;
    -> end //
Query OK, 0 rows affected (0.00 sec)

mysql> delimiter ;

5.创建存储过程proc002

sql 复制代码
mysql> delimiter //
mysql> create procedure proc002(in emp_name varchar(50))
    -> begin
    ->     select age from emp_new where name=emp_name;
    -> end //
Query OK, 0 rows affected (0.01 sec)

mysql> delimiter ;

6.创建存储过程proc003

sql 复制代码
mysql> delimiter //
mysql> create procedure proc003(in dept_id int,out avg_incoming decimal(10,2))
    -> begin
    ->    select round(avg(incoming),2) into avg_incoming from emp_new where deptt2=dept_id;
    -> end //
Query OK, 0 rows affected (0.00 sec)

mysql> delimiter ;
相关推荐
sun0077004 分钟前
dns命令排查解析nslookup
android
Database_Cool_7 分钟前
AnalyticDB MySQL vs Apache Doris:企业级云数仓如何选型——全维度对比指南
数据库·数据仓库·mysql·阿里云
Flash.kkl1 小时前
C++基于websocketpp的多用户网页五子棋项目
开发语言·网络·数据库·c++·websocket·mysql
问心无愧05131 小时前
ctf show web入门99
android·前端·笔记
plainGeekDev1 小时前
Handler/Looper → Coroutines
android·java·kotlin
awu的Android笔记1 小时前
限速/丢包/乱序/重复/篡改:Android 弱网模拟的 5 把利刃
android·tcp/ip
niech_cn1 小时前
uniapp开发App(iOS、Android、鸿蒙Next)之配置pages.json 页面路由(三)
android·ios·uni-app
杊页1 小时前
系列二:MVVM 深度实战与项目重构 | 第5篇 ViewModel 核心原理与实战避坑:它是如何“死而复生”的?
android
17715574311 小时前
unity6国际版安装及android SDK ,JDK,NDK安装
android
jingling5552 小时前
Flutter | 商城项目鸿蒙(OpenHarmony)适配实战
android·开发语言·前端·flutter·华为·harmonyos