MySQL练习05

题目

步骤

触发器

sql 复制代码
use mydb16_trigger;    #使用数据库

create table goods(
gid char(8) primary key,
name varchar(10),
price decimal(8,2),
num int);

create table orders(
oid int primary key auto_increment,
gid char(10) not null,
name varchar(10),
price decimal(8,2),
onum int,
otime date);

添加数据

sql 复制代码
insert into goods values
('A0001','橡皮',2.5,100),
('B0001','小楷本',2.8,210),
('C0001','铅笔',1.2,120),
('D0001','计算器',28,20);

输入触发器

sql 复制代码
create trigger insert_after_orders_trigger after insert
on orders for each row update goods
set num=num-new.onum where gid=new.gid;

删除触发器

sql 复制代码
create trigger delete_after_orders_trigger after
delete on orders for each row update goods
set num=num+old.onum where gid=old.gid;

更新触发器

sql 复制代码
create trigger update_after_orders_trigger
after update on orders
for each row update goods
set num=num+(old.onum-new.onum)
where gid=new.gid;

存储过程

存储过程s1

sql 复制代码
delimiter //    #切换命令分隔符
create procedure s1()
begin
          select name '姓名',incoming '工资' from emp_new;
end //
delimiter ;

存储过程s2

sql 复制代码
delimiter //    #更改命令结束符
create procedure s2(in in_name varchar(11), out out_age int)
begin
         select age into out_age from emp_new where name=in_name;
end //
delimiter ;

存储过程s3

sql 复制代码
delimiter //
create procedure s3(in in_dept2 int, out avg_sal double(10,2))
begin
         select avg(incoming) into avg_sal from emp_new where dept2=in_dept2;
end //
delimiter ;
相关推荐
程序员敲代码吗2 分钟前
用Python生成艺术:分形与算法绘图
jvm·数据库·python
未来的旋律~36 分钟前
sqlilabs注入靶场搭建与sql语句
数据库·sql
一个天蝎座 白勺 程序猿1 小时前
KingbaseES查询逻辑优化深度解析:从子查询到语义优化的全链路实践
开发语言·数据库·kingbasees·金仓数据库
我真的是大笨蛋1 小时前
InnoDB行级锁解析
java·数据库·sql·mysql·性能优化·数据库开发
山茶花.2 小时前
SQL注入总结
数据库·sql·oracle
m0_736919103 小时前
超越Python:下一步该学什么编程语言?
jvm·数据库·python
m0_748229993 小时前
ThinkPHP快速入门:从零到实战
c语言·开发语言·数据库·学习
阿蒙Amon3 小时前
C#每日面试题-Thread.Sleep和Task.Delay的区别
java·数据库·c#
沉舟侧畔千帆过_3 小时前
一个DBA的真心话:搞定Oracle+PG双库,我就靠这招
数据库·oracle·dba
奈斯ing3 小时前
【Oracle篇】基于OGG 21c全程图形化实现9TB数据从Oracle 11g到19c的不停机迁移(上):微服务架构详解与微服务部署,及同步问题总览(第一篇,总共三篇)
微服务·oracle·架构