MySQL第五次作业

  1. 触发器

·建立两个表:goods(商品表)、orders(订单表)

mysql> use mydb16_trigger;

mysql> create table goods

gidchar(8)primary key,

varchar(10),name

pricedecimal(8,2),

intnum

#商品编号

#商品名

#价格

#数量

mysql> create table orders

)

oid

#订单号intprimary keyauto increment.char(10)not null

gid

#商品号

name

varchar(10),

#商品名

pricedecimal(8,2)

#价格

int ,

#订单数量

onum

otimedate

#订单时间

在商品表中导入商品记录

mysql>insert into goods values

('A0001','橡皮',2.5,100)

('B0001','小楷本',2.8,210),

('C0001',铅笔',1.2,120)

('D0001',计算器"28,20);

·建立触发器,订单表中增加订单数量后,商品表商品数量同步减少对应的商品订单出数量,并测试

create trigger orders_after_insert_trigger

-> after insert on orders for each row

-> update goods set num=num-new.onum

-> where gid = new.gid;

·建立触发器,实现功能:客户取消订单,恢复商品表对应商品的数量

create trigger orders_after_delete_trigger

-> after delete on orders for each row

-> update goods set num=num+old.onum

-> where gid = old.gid;

建立触发器,实现功能:客户修改订单,商品表对应商品数量同步更新

create trigger orders_after_update_trigger

-> after update on orders for each row

-> update goods set num=num+(old.onum - new.onum)

-> where gid = old.gid;

2.存储过程

使用mydb7 openlab库

创建提取emp_new表所有员工姓名和工资的存储过程

create procedure s1()

-> begin

-> select name,incoming from emp_new;

-> end //

创建存储过程s2,实现输入员工姓名后返回员工的年龄

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 //

创建一个存储过程s3,有2个参数,传入部门号,返回该部门的平均工资

create procedure s3(in in_dept int,out avg_sal float)

-> begin

-> select avg(incoming) into avg_sal from emp_new where dept2=101;

-> end //

相关推荐
paopaokaka_luck21 分钟前
基于SpringBoot+Vue的非遗文化传承管理系统(websocket即时通讯、协同过滤算法、支付宝沙盒支付、可分享链接、功能量非常大)
java·数据库·vue.js·spring boot·后端·spring·小程序
小疯仔37 分钟前
navicat导出数据库的表结构
数据库
TOSUN同星38 分钟前
干货分享 | TSMaster DBC编辑器操作指南:功能详解+实战示例
数据库·oracle·编辑器·汽车·软件工程
huihui4502 小时前
一天一道Sql题(day01)
数据库
~尼卡~2 小时前
软考(软件设计师)数据库原理:事务管理,备份恢复,并发控制
数据库·软件设计师-软考
八九燕来2 小时前
Django双下划线查询
数据库·django·sqlite
眠りたいです2 小时前
Mysql常用内置函数,复合查询及内外连接
linux·数据库·c++·mysql
paopaokaka_luck3 小时前
智能推荐社交分享小程序(websocket即时通讯、协同过滤算法、时间衰减因子模型、热度得分算法)
数据库·vue.js·spring boot·后端·websocket·小程序
M1A13 小时前
Java 面试系列第一弹:基础问题大盘点
java·后端·mysql
He.ZaoCha3 小时前
函数-1-字符串函数
数据库·sql·mysql