软件测试必学的16个高频数据库操作及命令
数据库作为软件系统数据的主要存取与操作中心,广泛应用于企业当中。在企业中常用的数据库管理系统有 ORACLE、MS SQL SERVER、MySQL等。其中以免费的 MySQL 最多,特别在中小型互联网公司里。
因此,本文的数据库操作是基于 MySQL 数据库系统下的,我们收集了近 5 年里松勤学员在面试中碰到的高频出现的数据库操作及命令,供同学学习和参考,同时这些操作和命令也是企业日常工作中需要掌握的,因此希望大家尽量背下来。
1、数据表
1.1 学生表
Student(Snum,Sname,Sage,Ssex)
表字段解释:
Snum:学号;Sname:学生姓名;
Sage:学生年龄;Ssex:学生性别
1.2 课程表
Course(Cnum, Cname, Tnum)
表字段解释:
Cnum:课程编号;Cname:课程名字;Tnum:教师编号
1.3 成绩表
SC(Snum. Cnum,score)成绩表
表字段解释:
Snum:学号;Cum:课程编号;score:成绩
2、查询平均成绩大于 60 分的同学的学号和平均成绩?
参考答案:
select Snum,avg(score) from sc group by Snum having avg(score)>60;
3、查询姓“李”的老师的个数?
参考答案:
select count(distinct(Tname)) from Teacher where Tname like ‘李%’;
4、查询所有同学的学号、姓名、选课数、总成绩?
参考答案:
select Student.Snum,Student.Sname,count(SC.Cnum),sum(score)
from Student left Outer join SC on Student.Snum=SC.Snum
group by Student.Snum,Sname;
5、查询没学过“叶平”老师课的同学的学号、姓名?
参考答案:
select Student.Snum,Student.Sname from Student where Snum not in (select distinct( SC.Snum) from SC,Course,Teacher where SC.Cnum=Course.Cnum and Teacher.Tnum=Course.Tnum and Teacher.Tname='叶平);
6、查询学过“001”并且也学过编号“002”课程的同学的学号、姓名?
参考答案:
Select Student.Snum,Student.Sname from Student,SC where Student.Snum=SC.Snum and SC.Cnum='001’and exists( Select * from SC as SC_2 where SC_2.Snum=SC.Snum and SC_2.Cnum=‘002’);
7、查询学过“叶平”老师所教的所有课的同学的学号、姓名?
参考答案:
select Snum,Sname from Student where Snum in (select Snum fromSC ,Course ,Teacher where SC.Cnum=Course.Cnum and Teacher.Tnum=Course.Tnum and Teacher.Tname=‘叶平’ group by Snum having count(SC.Cnum)=(select count(Cnum) from Course,Teacher where Teacher.Tnum=Course.Tnum and Tname=‘叶平’))
8、查询课程编号“002"的成绩比课程编号”001”课程低的所有同学的学号、姓名?
参考答案:
Select Sum,Sname from (select Student.Snum,Student.Sname,score , (select score t=from SC SC_2 where SC_2.Snum=Sudet.Snum and SC_2.Cnum=‘002’) score2 from Student,SC where Student.Snum=SC.Snum and Cnum=‘001’) S_2 where score2
9、 查询所有课程成绩小于 60 分的同学的学号、姓名?
参考答案:
select Snum,Sname from Student where Snum not in (select Sudent.Snum from Student,SC where S.Snum=SC.Snum and score>60);
10、查询没有学全所有课的同学的学号、姓名?
参考答案:
select Student.Snum,Student.Sname from Student,SC where Student.Snum=SC.Snum group by Student.Sname,Student.Sname having count(Cnum)<(select count(Cnum)from Course);
11、查询至少有一门课与学号为“101”的同学所学相同的同学的学号和姓名?
参考答案:
select Snum,Sname from Student,SC where Student.Snum-SC.Snum and Cnum in select Cnum from SC where Snum=‘1001’;
12、查询至少学过学号为“001”同学所有一门课的其他同学学号和姓名?
参考答案:
select distinct SC.Snum,Sname from Student,SC where Student.Snum=SC.Snum and Cnum in (select Cnum from SC where Snum=‘001’);
13、把“SC"表中“叶平”老师教的课的成绩都更改为此课程的平均成绩?
参考答案:
update SC set score=(select avg(SC_ 2.score) from SC SC_2 where SC_ 2.Cnum=SC.Cnum ) from Course,Teacher where Course.Cnum=SC.Cnum and Course.Tnum=Teacher.Tnum and Teacher.Tname=‘叶平’);
14、查询和“1002”号的同学学习的课程完全相同的其他同学学号和姓名?
参考答案:
select Snum from SC where Cnum in (select Cnum from SC where Snum=‘1002’) group by Snum having count()=(select count() from SC where Snum=‘1002’);
15、删除学习“叶平”老师课的 SC 表记录?
参考答案:
Delect SC from course ,Teacher where Course.Cnum=SC.Cnum and Course.Tnum= Teacher.Tnum and Tname=‘叶平’;
16、向SC表中插入一些记录,这些记录要求符合以下条件:没有上过编号“003" 课程的同学学号、2 号课的平均成绩?
参考答案:
lnsert SC select Snum,‘002’, (Select avg(score) from SC where Cnum=‘002’) from Student where Snum not in (Select Snum from SC where Cnum=‘002’);
最后: 可以在 这里这里这里这里 免费领取一份216页软件测试工程师面试宝典文档资料。以及相对应的视频学习教程免费分享!,其中包括了有基础知识、Linux必备、Shell、互联网程序原理、Mysql数据库、抓包工具专题、接口测试工具、测试进阶-Python编程、Web自动化测试、APP自动化测试、接口自动化测试、测试高级持续集成、测试架构开发测试框架、性能测试、安全测试等。
学习就不要孤军奋战,最好是能抱团取暖,相互成就一起成长,群众效应的效果是非常强大的,大家一起学习,一起打卡,会更有学习动力,也更能坚持下去。你可以加入我们的测试技术交流扣扣群:914 172 719(里面有各种软件测试资源和技术讨论)
软件测试必学的16个高频数据库操作及命令相关推荐
- 软件测试必学内容,你都掌握了吗?
前言 软件测试做为IT行业的高薪技术岗,很多人非常看好它的发展前途,想要从事或者转行进入这个岗位.但这毕竟是一份技术岗,是需要对软件测试有一定了解和经验的,很多人就想先学习一下再上岗,那软件测试需要学 ...
- 软件测试必学之python+unittest+requests+HTMLRunner编写接口自动化测试集
问题描述: 搭建接口测试框架,执行用例请求多个不同请求方式的接口 实现步骤: ① 创建配置文件config.ini,写入部分公用参数,如接口的基本url.测试报告文件路径.测试数据文件路径等配置项 1 ...
- web前端知识点太多_web前端入门必学的16个知识点,都来看一下吧
1.HTML常用标签 语言是什么 .Web前端开发语言. HTML超文本标记语言 . 网页主体结构 .常用标签.超链接(a标签).Img图片标签 2.盒子模型 初探Div盒子模型 .css样式. 简单 ...
- 零基础小白软件测试必学python5公共操作和推导式
运算符 str1 = '123' str2 = '2' list1 = [1, '2'] list2 = [3, 4] tuple1 = (1, 2, '3') tuple2 = (4, 5, 6) ...
- 亲亲亲亲兄弟们必学成为首富第一步学习Linux基础命令
有小粉丝问了:杨哥杨哥想学习Linux学不懂怎么办,没关系跟着杨哥一步一步来,都是杨哥的亲兄弟,杨哥决定自学把自己的毕生所学都交给兄弟们 cd /进入目录 cd /mnt [root /mnt]:mk ...
- Android内部自带的SQLite数据库操作dos命令
1:什么叫做SQLite数据库 Android系统内核是Linux系统,Android系统很特殊,他自带了一个SQLite数据库,轻量型的一款嵌入式的数据库 它占用资源非常的低,在嵌入式设备中,可能只 ...
- mysql5.5数据库操作_命令行下mysql数据库基本操作
安装:在64位的Win7上安装的是mysql-5.5.28-winx64.msi, 才30M多一点.最初安装的是5.6的版本,每次安装完成之后不会自动进入"Mysql Server Inst ...
- 初级程序员必学Java 教程
Java 教程 Java 是由 Sun Microsystems 公司于 1995 年 5 月推出的高级程序设计语言. Java 可运行于多个平台,如 Windows, Mac OS 及其他多种 UN ...
- Django-- (三) Django数据库操作
1.Django数据库 Django 非常适合构建数据库驱动型网站,它提供了简单而强大的工具(ORM),易于使用 Python 执行数据库查询. 2.ORM介绍 Object Relational M ...
- MongoDB数据库操作---mongoose操作
Mongoose认知概念 Mongoose是MongoDB的一个对象模型工具,其可以在一部环境下执行.同时它也是针对MongoDB操作的一个队形模型库,封装了MongoDB对文档的一些增删改查等常用方 ...
最新文章
- OneAPM挂牌新三板,续写 ITOM 新篇章
- java修改数据库表结构_数据库设计(一):设计传统系统表结构(Java开发)
- C#将文件压缩或者解压
- [leetcode] 53.最大子序和
- JavaScript中OOP——面向对象中的继承/闭包
- 莫队算法 BOJ 2038 [2009国家集训队]小Z的袜子(hose)
- Python学习路线介绍
- Unity2020.1新功能探路:光照相关更新
- SQL删除数据表中指定列重复的数据
- android bin目录是什么,android bin目录下的.ap_是神马文件?
- 企业如何用好云、管好云?
- 使用react-pdf预览pdf
- 无线网络的几种认证与加密方式
- MySQL的函数以及相关案例与练习
- HTML标签--换行标签与段落标签的区别对比
- 从来不敷面膜的人_女人一旦过了40岁,敷面膜要记住“3不要”,否则还不如不敷!...
- 如何实现开票申请及其审核功能
- 地理学(第一、第二)定律
- 【jiasuba】分享:键盘失灵烦恼多 教你轻松禁用原键盘
- 微信小程序----事件绑定
热门文章
- dokcer基础命令-详解
- Qt编写的SMTP客户端(库)
- MySQL初始密码忘记了怎么办
- java 中counter什么意思_方便适用的计数器Counter
- 基站定位(Google API)
- Google SketchUp Cookbook: (Chapter 5) Roofs: Constraints and Inferences
- oracle 范鑫_快速理解数据库中的索引(Indexes in Database)
- 12个可以免费自学编程的网站
- 终端设置指南,让Mac/Linux/Windows终端更上一层楼
- go语言能开发什么?go语言开发案例