欧鹏 数据库 第五次作业

文章目录

  • 第五次作业题目
    • 一,触发器
      • 1)建立两个表:good(商品表),orders(订单表)
    • 二,在商品表中导入记录
    • 三,储存过程
  • 1)建立触发器,订单中增加订单数量后,商品表数量同步减少对应的商品订单出单数量,并测试
  • 2)建立触发器,实现功能:客户取消订单,恢复商品表对应商品的数量
  • 3)建立触发器,实现功能:客户修改订单,商品表对应商品数量同步更新
  • 1)使用db_mysql_7库
  • 2)建立提取emp_new表所有员工姓名和工资的储存过程s1
  • 4)建立储存过程s3, 有两个参数,传入部门号,返回该部门的平均工资

第五次作业题目

一,触发器

1)建立两个表:good(商品表),orders(订单表)

create database db_mysql_7;#(库名自拟)
use db_mysql_7;
create table goods (gid char(8) primary key , name varchar(10) , price decimal(8,2) , num int);
create table orders (old int primary key auto_increment , gid char(10) not null , name varchar(10) , price decimal(8,2) , onum int , otime date);

二,在商品表中导入记录

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

1)建立触发器,订单中增加订单数量后,商品表数量同步减少对应的商品订单出单数量,并测试
2)建立触发器,实现功能:客户取消订单,恢复商品表对应商品的数量
3)建立触发器,实现功能:客户修改订单,商品表对应商品数量同步更新

三,储存过程

1)使用db_mysql_7库
2)建立提取emp_new表所有员工姓名和工资的储存过程s1
3)建立储存过程s2,实现输入员工姓名后返回员工的年龄
4)建立储存过程s3, 有两个参数,传入部门号,返回该部门的平均工资

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

delimiter $$
create trigger trg_after_order_insert
after insert on orders
for each row
beginupdate goods set num = num - new.onum where gid = new.gid;
end$$
delimiter ;

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

delimiter $$
create trigger trg_after_order_delete
after delete on orders
for each row
begin update goods set num = num + old.onum where gid = old.gid;
end$$
delimiter ;

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

delimiter $$
create trigger trg_after_order_update
after update on orders
for each row
beginif old.onum <> new.onum thenupdate goods set num = num + (old.onum -new.onum) where gid =new.gid;end if;
end$$
delimiter ;

1)使用db_mysql_7库

use db_mysql_7;

2)建立提取emp_new表所有员工姓名和工资的储存过程s1

delimiter $$
create procedure s1()
beginselect name , salary from emp_new;
end$$
delimiter ;
# 3)建立储存过程s2,实现输入员工姓名后返回员工的年龄
```mysql
delimiter $$
create procedure s2(in emp_name varchar(255))
beginselect age from emp_new where name = emp_name;
end$$
delimiter ;

4)建立储存过程s3, 有两个参数,传入部门号,返回该部门的平均工资

delimiter $$
create procedure s3(in dept_id int)
beginselect avg(salary) as avg_salary from emp_new where dept_id = dept_id;
end$$
delimiter ;

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/876429.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

QT 5 同时使用Q_DECLARE_METATYPE(pointdata) 和继承 QObjectUserData

在Qt框架中&#xff0c;QObjectUserData 和 Q_DECLARE_METATYPE() 宏都与Qt的元对象系统有关&#xff0c;但它们的使用方式有一些特别的限制和兼容性问题。 关于QObjectUserData&#xff1a; QObjectUserData 是一个用来存储用户数据的类。在Qt中&#xff0c;每个 QObject 可以…

CI/CD学习之路

CI/CD之路 https://mp.weixin.qq.com/mp/appmsgalbum?__bizMzg4NDg0MjQ0MQ&actiongetalbum&album_id3433192036428447744&scene173&subscene&sessionidsvr_0b1e7fe1d6b&enterid1721879847&from_msgid2247485821&from_itemidx1&count3&am…

【漏洞复现】ServiceNow UI Jelly模板注入(CVE-2024-4879)

声明&#xff1a;本文档或演示材料仅用于教育和教学目的。如果任何个人或组织利用本文档中的信息进行非法活动&#xff0c;将与本文档的作者或发布者无关。 一、漏洞描述 ServiceNow是一家专注于提供企业级云计算服务的企业&#xff0c;其旗舰产品是基于云的服务管理解决方案&…

视觉巡线小车(STM32+OpenMV)——总结

文章目录 目录 文章目录 前言 一、效果展示 二、完整流程 1、STM32CubeMX配置 2、Keil编辑 3、硬件接线 4、参数调试 5、图像处理调试 三、总结 前言 基于前面的系列文章&#xff0c;已基本介绍完了基于STM32OpenMV的视觉巡线小车&#xff0c;本文将以小编自己的小车…

SeaCMS海洋影视管理系统远程代码执行漏洞复现

SeaCMS海洋影视管理系统远程代码执行漏洞复现 Ⅰ、环境搭建Ⅱ、漏洞复现Ⅲ、漏洞分析 免责声明&#xff1a;请勿利用文章内的相关技术从事非法测试&#xff0c;由于传播、利用此文所提供的信息或者工具而造成的任何直接或者间接的后果及损失&#xff0c;均由使用者本人负责&…

Greenplum数据库中常用的聚合函数及其对应的分析函数

一、SUM()函数及其对应的分析函数&#xff08;SUM() OVER&#xff09; SUM()函数是一种常用的聚合函数&#xff0c;用于计算某一列的总和。在Greenplum数据库中&#xff0c;SUM()函数可以与分析函数SUM() OVER结合使用&#xff0c;实现对某一列的累计求和操作。 语法示例&…

全栈嵌入式C++、STM32、Modbus、FreeRTOS和MQTT协议:工业物联网(IIoT)可视化系统设计思路(附部分代码解析)

项目概述 随着工业4.0时代的到来&#xff0c;工业物联网&#xff08;IIoT&#xff09;在提高生产效率、降低运营成本和实现智能制造方面得到了广泛应用。本项目旨在开发一个全面的工业物联网监控系统&#xff0c;能够实时监测设备的温度、压力、振动和电流等参数&#xff0c;并…

【Python实战因果推断】60_随机实验与统计知识2

目录 An A/B Testing Example An A/B Testing Example 在许多公司中&#xff0c;一种常见的策略是提供廉价甚至免费的产品&#xff0c;这种产品本身可能并不盈利&#xff0c;但其目的是吸引新客户。一旦公司获得了这些客户&#xff0c;就可以向他们推销其他更盈利的产品&#x…

ThinkPHP一对一关联模型的运用(ORM)

一、序言 最近在写ThinkPHP关联模型的时候一些用法总忘&#xff0c;我就想通过写博客的方式复习和整理下一些用法。 具体版本&#xff1a; topthink/framework&#xff1a;6.1.4topthink/think-orm&#xff1a;2.0.61 二、实例应用 1、一对一关联 1.1、我先设计了两张表&#x…

Makefile 如何将生成的 .o 文件放到指定文件夹

研究了不少文章&#xff0c;我行通了一个&#xff0c;但是也不全&#xff0c;目前只能适用当前文件夹&#xff0c;如果源文件有子文件夹处理不了&#xff0c;还得继续研究。很多人说编译完把O文件移动走或者直接删掉。我想说的是不符合我的要求&#xff0c;移走或者删除O文件&a…

git使用报错 无法切换到master,因存在未提交的更改。 在切换分支之前提交或撤消更改。 有关详细信息,请查看“输出”窗口

"git使用报错 无法切换到master&#xff0c;因存在未提交的更改。 在切换分支之前提交或撤消更改。 有关详细信息&#xff0c;请查看“输出”窗口" 这个错误消息通常出现在你尝试切换Git分支时&#xff0c;当前工作目录中有未提交的更改。Git会阻止你切换分支&#…

Linux下的网络通讯

UDP&#xff1a;用户数据报协议 传输层 特点: 1.无连接 2.不安全、不可靠 3.面向报文 4.占用资源开销小 TCP : 传输控制协议 传输层 1. TCP特点: 1.面向连接 2.安全、可靠 3.面向字节流 4.占用资源开销大 三次握手: 指建立tc…

[SWPU2019]Web1

上来看到两个功能&#xff0c;登录和注册&#xff0c;看到登录框直接sqlmap嗦一下 失败 注册admin显示被注册&#xff0c;那就注册一个账密都为aaa 登录进来发现两个功能点 发了一个广告却显示代管理确认&#xff0c;这里肯定没有管理员&#xff0c;所以我们得想办法自己上去a…

lxml.etree模式使用(一)

from lxml import etree from copy import deepcopydef prettyprint(element, **kwargs):print("/")xml etree.tostring(element, pretty_printTrue, **kwargs)print(xml.decode(), end)# 1. 创建元素 root etree.Element("root")# 2. 添加子元素 root.a…

【Python】基础学习技能提升代码样例3:JSON文本处理

对json的处理&#xff0c;无非是编码和解码两部分 编码&#xff1a;将python数据结构转换为json字符串解码: 将json字符串转换为python数据结构 另外&#xff0c;还有.json文件的读写 一、编码 json.dumps(obj, *, skipkeysFalse, ensure_asciiTrue, check_circularTrue, a…

React特点

React 是一个用于构建用户界面的 JavaScript 库&#xff0c;由 Facebook 开发并维护。React 的特点主要体现在以下几个方面&#xff1a; 声明式&#xff08;Declarative&#xff09;&#xff1a;React 使你能够以一种声明的方式来描述你的 UI&#xff0c;这使得代码更加容易理解…

铲屎官的必备好物——希喂、352、米家养宠空气净化器分享

对于每一位深爱着家中萌宠的铲屎官而言&#xff0c;无尽的温情往往也伴随着日常生活中的小烦恼。那些不经意间飘散在空气中的毛发&#xff0c;偶尔缠绕在鼻腔或口腔中的细微触感&#xff0c;以及偶尔袭来的不明异味&#xff0c;都是与宠物共度的日子里不可或缺的一部分。幸好随…

聊聊RNNLSTM

RNN 用于解决输入数据为&#xff0c;序列到序列(时间序列)数据&#xff0c;不能在传统的前馈神经网络(FNN)很好应用的问题。时间序列数据是指在不同时间点上收集到的数据&#xff0c;这类数据反映了某一事物、现象等随时间的变化状态或程度&#xff0c;即输入内容的上下文关联…

基于Orangepi全志H616开发嵌入式数据库——SQLite

目录 一、SQLite数据库 1.1 SQLite 的特点&#xff1a; 1.2 SQLite 的使用场景&#xff1a; 1.3 SQLite数据库与传统MySQL数据库的区别&#xff1a; 二、SQLite数据库安装 2.1 SQLite数据库安装方式一&#xff1a; 2.2 SQlite数据库安装方式二&#xff1a; 三、SQLite数…

Nacos适配达梦数据库并制作镜像

背景&#xff1a;因项目需要信创&#xff0c;需将原本的mysql数据库&#xff0c;改成达梦数据库 一、部署达梦数据库 1.1 部署达梦数据库服务 可参考&#xff1a;Docker安装达梦数据库_达梦数据库docker镜像-CSDN博客 1.2 创建nacos数据库 create user SAFE_NACOS identifi…