Mysql配套测试之更新篇

🏝️专栏:Mysql_猫咪-9527的博客-CSDN博客

🌅主页:猫咪-9527-CSDN博客

"欲穷千里目,更上一层楼。会当凌绝顶,一览众山小。"

目录

测试准备:

[更新测试 :](#更新测试 :)

1.将孙悟空同学的数学成绩更新为80

2.将曹孟德同学的数学成绩变更为60分,数学成绩变更为70分

3.将总成绩后三名的同学,数学成绩加上三十分

删除测试:

4.删除孙悟空同学的成绩

5.删除总成绩最后一名的同学

6.删除整张表的数据

7.删除表中重复元素

聚合测试:

8.统计不重复的数学成绩

9.统计数学成绩和

10.统计数学平均分

11.找出七十分以上的最低分

分组测试:

12.查看组内的最高工资和平均工资

​编辑

13.显示每种岗位的最低工资和平均工资

14.显示每个部门的每种岗位的平均工资和最低工资

15.显示平均工资低于2000的部门和他的平均工资

测试准备:

(1)创建一个测试数据库

复制代码
create databate text_3_22;

(2)进入数据库

复制代码
use text_3_22;

(3)创建表并插入数据(我已经为你们准备好了,记得插入后再进行测试)

复制代码
-- 创建表结构
create table exam_result (
  id int unsigned primary key auto_increment,
  name varchar(20) not null comment '同学姓名',
  chinese float default 0.0 comment '语文成绩',
  math float default 0.0 comment '数学成绩',
  english float default 0.0 comment '英语成绩'
);

-- 插入测试数据
insert into exam_result (name, chinese, math, english) values
('唐三藏', 67, 98, 56),
('孙悟空', 87, 78, 77),
('猪悟能', 88, 98, 90),
('曹孟德', 82, 84, 67),
('刘玄德', 55, 85, 45),
('孙权', 70, 73, 78),
('宋公明', 75, 65, 30);

(4)记得检验自己插入的数据是否正确

复制代码
select *from exam_result;

更新测试 :

1.将孙悟空同学的数学成绩更新为80
复制代码
update exam_result set math=80 where name='孙悟空';

|-----------------------------------------------------------------------------|-----------------------------------------------------------------------------|
| 更新前: | 更新后 |
| ​ | ​ |

2.将曹孟德同学的数学成绩变更为60分,数学成绩变更为70分
复制代码
update exam_result set math=60,chinese=70 
where name='曹孟德'; 

|----------------------------------------------------------------------------|----------------------------------------------------------------------------|
| 更新前: | 更新后 |
| | |

3.将总成绩后三名的同学,数学成绩加上三十分
复制代码
update exam_result set math=math+30 order 
by math+english+chinese asc limit 3;

|----------------------------------------------------------------------------|----------------------------------------------------------------------------|
| 更改前后三名 | 更改后后三名: |
| | |

删除测试:

4.删除孙悟空同学的成绩
复制代码
delete from exam_result where name='孙悟空';

|----------------------------------------------------------------------------|----------------------------------------------------------------------------|
| 删除前 | 删除后 |
| | |

5.删除总成绩最后一名的同学
复制代码
delete from exam_result order by english+math+chinese asc limit 1;

|----------------------------------------------------------------------------|----------------------------------------------------------------------------|
| 删除前: | 删除后: |
| | |

6.删除整张表的数据
复制代码
CREATE TABLE for_delete (
id INT PRIMARY KEY AUTO_INCREMENT,
name VARCHAR(20)
);

---准备一个测试表结构

insert for_delete (name) values('a'),('b'),('c');

----准备测试数据

|-------------------------|----------------------|
| 方案一:删除表 | 方案二:截断表 |
| delete from for_delete; | truncate for_delete; |

7.删除表中重复元素
复制代码
create table 1_distinct_text(
name varchar(20)
);
---创建测试表

insert 1_distinct_text values
('aaa'),('bbb'),('aaa'),('bbb'),('aaa'),('bbb');

|------------------------------------------|----------------------------------------------------|
| 创建相同的表结构 | 创建相同表结构并插入去重元素 |
| create table <新表名> like <原表名>; | create table <新表名> as select distinct *from <旧表名>; |
| 在新表中插入去重数据 | create table <新表名> as select distinct *from <旧表名>; |
| insert <新表名> select distinct *from<原表名>; | create table <新表名> as select distinct *from <旧表名>; |
| 删除旧表 ||
| drop table <旧表>; ||
| 改新表名为旧表 ||
| alter table <新表名> rename to <旧表名> ||

聚合测试:

8.统计不重复的数学成绩
复制代码
select count(math) from exam_result;

|----------------------------------------------------------------------------|----------------------------------------------------------------------------|
| 统计所有数学成绩 | 统计不重复数学成绩 |
| | |

9.统计数学成绩和
复制代码
select sum(math) from exam_result;
10.统计数学平均分

方案一:

复制代码
select sum(math)/count(math) from exam_result;

方案二:

复制代码
select avg (math) from exam_result;
11.找出七十分以上的最低分
复制代码
select min(math) from exam_result where math>70;

分组测试:

注:准备数据导入到数据库里面(scott_data.sql

导入操作在(Mysql的库操作-CSDN博客)中的数据恢复里面

案例:

  • 准备工作,创建一个雇员信息表(来自oracle 9i的经典测试表)
  • EMP员工表
  • DEPT部门表
  • SALGRADE工资等级表
  • 如何显示每个部门的平均工资和最高工资
12.查看组内的最高工资和平均工资
复制代码
select max(sal),avg(sal) from emp group by deptno;
13.显示每种岗位的最低工资和平均工资
复制代码
select min(sal),avg(sal) from emp group by job;
14.显示每个部门的每种岗位的平均工资和最低工资
复制代码
select min(sal),avg(sal) from emp group by deptno,jop;
15.显示平均工资低于2000的部门和他的平均工资
复制代码
select deptno ,avg(sal) deptsal from emp group by deptno
having deptsal<2000;
相关推荐
努力打怪升级7 小时前
使用 pymssql 连接数据库(GBK 编码)乱码问题的完美解决方案
数据库
却话巴山夜雨时i8 小时前
互联网大厂Java面试场景:从Spring到微服务的逐层提问
java·数据库·spring·微服务·日志·性能监控
oradh8 小时前
Oracle数据库网络体系结构概述
数据库·oracle·数据库基础·数据库入门·oracle网络基础
满天星83035778 小时前
【MySQL】表的基本查询(上)
linux·服务器·数据库·mysql
川石课堂软件测试8 小时前
涨薪技术|Prometheus使用Recoding Rules优化性能
功能测试·测试工具·jmeter·mysql·面试·单元测试·prometheus
主角1 78 小时前
MySQL高可用集群
数据库·mysql
dajun1811234568 小时前
信息系统运维管理全流程详解 在线画图工具绘制运维流程图表技巧
运维·数据库·信息可视化·流程图·旅游·论文笔记
流觞 无依8 小时前
SQLite数据库损坏修复指南——解决“database disk image is malformed”报错
jvm·数据库·sqlite
道清茗8 小时前
【MySQL知识点问答题】 安全与性能管理
数据库·mysql
2501_920627618 小时前
Flutter 框架跨平台鸿蒙开发 - 数据库学习助手
数据库·学习·flutter·华为·harmonyos