数据库作为软件系统数据的主要存取与操作中心,广泛应用于企业当中。在企业中常用的数据库管理系统有 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个高频数据库操作及命令相关推荐

  1. 软件测试必学内容,你都掌握了吗?

    前言 软件测试做为IT行业的高薪技术岗,很多人非常看好它的发展前途,想要从事或者转行进入这个岗位.但这毕竟是一份技术岗,是需要对软件测试有一定了解和经验的,很多人就想先学习一下再上岗,那软件测试需要学 ...

  2. 软件测试必学之python+unittest+requests+HTMLRunner编写接口自动化测试集

    问题描述: 搭建接口测试框架,执行用例请求多个不同请求方式的接口 实现步骤: ① 创建配置文件config.ini,写入部分公用参数,如接口的基本url.测试报告文件路径.测试数据文件路径等配置项 1 ...

  3. web前端知识点太多_web前端入门必学的16个知识点,都来看一下吧

    1.HTML常用标签 语言是什么 .Web前端开发语言. HTML超文本标记语言 . 网页主体结构 .常用标签.超链接(a标签).Img图片标签 2.盒子模型 初探Div盒子模型 .css样式. 简单 ...

  4. 零基础小白软件测试必学python5公共操作和推导式

    运算符 str1 = '123' str2 = '2' list1 = [1, '2'] list2 = [3, 4] tuple1 = (1, 2, '3') tuple2 = (4, 5, 6) ...

  5. 亲亲亲亲兄弟们必学成为首富第一步学习Linux基础命令

    有小粉丝问了:杨哥杨哥想学习Linux学不懂怎么办,没关系跟着杨哥一步一步来,都是杨哥的亲兄弟,杨哥决定自学把自己的毕生所学都交给兄弟们 cd /进入目录 cd /mnt [root /mnt]:mk ...

  6. Android内部自带的SQLite数据库操作dos命令

    1:什么叫做SQLite数据库 Android系统内核是Linux系统,Android系统很特殊,他自带了一个SQLite数据库,轻量型的一款嵌入式的数据库 它占用资源非常的低,在嵌入式设备中,可能只 ...

  7. mysql5.5数据库操作_命令行下mysql数据库基本操作

    安装:在64位的Win7上安装的是mysql-5.5.28-winx64.msi, 才30M多一点.最初安装的是5.6的版本,每次安装完成之后不会自动进入"Mysql Server Inst ...

  8. 初级程序员必学Java 教程

    Java 教程 Java 是由 Sun Microsystems 公司于 1995 年 5 月推出的高级程序设计语言. Java 可运行于多个平台,如 Windows, Mac OS 及其他多种 UN ...

  9. Django-- (三) Django数据库操作

    1.Django数据库 Django 非常适合构建数据库驱动型网站,它提供了简单而强大的工具(ORM),易于使用 Python 执行数据库查询. 2.ORM介绍 Object Relational M ...

  10. MongoDB数据库操作---mongoose操作

    Mongoose认知概念 Mongoose是MongoDB的一个对象模型工具,其可以在一部环境下执行.同时它也是针对MongoDB操作的一个队形模型库,封装了MongoDB对文档的一些增删改查等常用方 ...

最新文章

  1. OneAPM挂牌新三板,续写 ITOM 新篇章
  2. java修改数据库表结构_数据库设计(一):设计传统系统表结构(Java开发)
  3. C#将文件压缩或者解压
  4. [leetcode] 53.最大子序和
  5. JavaScript中OOP——面向对象中的继承/闭包
  6. 莫队算法 BOJ 2038 [2009国家集训队]小Z的袜子(hose)
  7. Python学习路线介绍
  8. Unity2020.1新功能探路:光照相关更新
  9. SQL删除数据表中指定列重复的数据
  10. android bin目录是什么,android bin目录下的.ap_是神马文件?
  11. 企业如何用好云、管好云?
  12. 使用react-pdf预览pdf
  13. 无线网络的几种认证与加密方式
  14. MySQL的函数以及相关案例与练习
  15. HTML标签--换行标签与段落标签的区别对比
  16. 从来不敷面膜的人_女人一旦过了40岁,敷面膜要记住“3不要”,否则还不如不敷!...
  17. 如何实现开票申请及其审核功能
  18. 地理学(第一、第二)定律
  19. 【jiasuba】分享:键盘失灵烦恼多 教你轻松禁用原键盘
  20. 微信小程序----事件绑定

热门文章

  1. dokcer基础命令-详解
  2. Qt编写的SMTP客户端(库)
  3. MySQL初始密码忘记了怎么办
  4. java 中counter什么意思_方便适用的计数器Counter
  5. 基站定位(Google API)
  6. Google SketchUp Cookbook: (Chapter 5) Roofs: Constraints and Inferences
  7. oracle 范鑫_快速理解数据库中的索引(Indexes in Database)
  8. 12个可以免费自学编程的网站
  9. 终端设置指南,让Mac/Linux/Windows终端更上一层楼
  10. go语言能开发什么?go语言开发案例