一、现有以下两张表:

第一张表名为cust,其表结构如下:

字段名 字段说明 是否主键
Studentno 学号,数据类型为整型的
Name 学生名字,数据类型为字符串型的
Address 学生住址,数据类型为字符串型的
Telno 电话号码,数据类型为字符串型的

第二张表名为mark,其表结构如下:

字段名 字段说明 是否为主键
studentno 学号,数据类型为整型的
english 英语成绩,数据类型为数字型的
math 数学成绩,数据类型为数字型的
computer 计算机成绩,数据类型为数字型的

1)   [5分]请写出计算 所有学生的英语平均成绩的sq|语句。

SELECT
a.Studentno,
a. NAME,
b.english
FROM
cust a
JOIN mark b ON a.Studentno = b.studentno

  

2)   [5分]现有五 个学生,其学号假定分别为11,22,33,44,55;请用一条SQL语句实现列出这五个学生的数学成绩及其姓名、学生地址、电话号码;

SELECT
a. NAME,
b.math,
a.Address,
a.Telno
FROM
cust a
JOIN mark b ON a.Studentno = b.studentno
WHERE
a.Studentno IN (11, 22, 33, 44, 55);

  

3)[5分]查询所有学生的姓名、计算机成绩,按照计算机成绩从高到低排序;

SELECT
a. NAME,
b.computer
FROM
cust a
JOIN mark b ON a.Studentno = b.studentno
ORDER BY
b.computer DESC;

  

4)[5分]查询所有总成绩大于240分的学生学号、姓名、总成绩,按照总成绩从高到低排序;

SELECT
a.Studentno,
a. NAME,
sum(b.math + b.english + b.computer) zcj
FROM
cust a
JOIN mark b ON a.Studentno = b.studentno
GROUP BY
a.Studentno,
a. NAME
HAVING
zcj > 240
ORDER BY
zcj DESC;

  

二、

表名 字段 备注
student id 学号
name 学生姓名
course id 课程编号
name 课程名称
sc sid 学号
cid 课程编号
score 成绩

请写出如下SQL:

A.查询姓‘王’的学生的个数;

select count(*) from student where name like '王%';

B. 查询“数学”比“语文”成绩高的所有学生的学号;

法一:使用case...when.. then...end语句: 

select a.id,a.name,
sum(case when c.name='语文' then b.score end) chinese,
sum(case when c.name='数学' then b.score end) math
from student a
join sc b on a.id=b.sid
join course c on c.id=b.cid
group by a.id,a.name
having math>chinese

法二:嵌套查询的方式:

select student.id from student,
(select * from sc where cid=(select id from course where name='语文')) chinese,
(select * from sc where cid=(select id from course where name='数学')) math
where student.id=chinese.sid
and chinese.sid=math.sid
and math.score>chinese.score 

C.查询平均成绩大于90分的同学的学号和平均成绩。

不涉及到学科的问题,只需关联学生表和成绩表即可:

SELECT
a.id,
a. name,
avg(b.score)
FROM
student a
JOIN sc b ON a.id = b.sid
GROUP BY
id,
name
HAVING
avg(b.score) > 90; 

解题思路:

第二题中,①首先,要知道的是学生的id,姓名和语数成绩,查询出来如下所示:

②用case...when...then...end语句,分别查询出课程名为语文和数学的成绩,如下图所示:

注意:这里注意,为什么需要写两个case...when...then...end语句,因为我们要显示的是两列,实现分组功能

③去null值,用聚合函数,求和、最大值、最小值都可以

④筛选出数学成绩大于语文成绩的,having即可

第三题求平均成绩,不涉及到课程,只需要关联两张表即可

三、

查询学生信息表中男生一共有多少人

select count(*) from t_student where sex='男'

查询男生成绩中前3名的成绩

SELECT
b.score
FROM
student a
JOIN sc b ON a.id = b.sid
WHERE
sex = '男'
ORDER BY
b.score DESC
LIMIT 3  

查询男生成绩中排名第3的成绩  

SELECT
b.score
FROM
student a
JOIN sc b ON a.id = b.sid
WHERE
sex = '男'
ORDER BY
b.score DESC
LIMIT 2,1  

如果在上一题的基础上,若第三名的男生成绩有重复的两个

distinct去重,会把重复的去掉,只保留一个

SQL笔试真题练习的更多相关文章

  1. 网易实习笔试真题C/C++

    刚做的时候根本就没有想到解题思路,刚好看到了别人的思路,自己写了一下.里面对unordered_map及vector二维数组的建立很灵活,另外区别了一下map,unordered_map,hash_m ...

  2. 美团点评2017校招笔试真题-算法工程师A

    美团点评2017校招笔试真题-算法工程师A 1.下面哪种STL容器的实现和其它三个不一样 A. set B. deque C. multimap D. map 正确答案: B STL的容器可以分为以下 ...

  3. 美团点评2017校招笔试真题-算法工程师B

    美团点评2017校招笔试真题-算法工程师B 1.以下关于经典的k-means聚类的说法哪个是错误的? A:k-means聚类算法是全局收敛的 B:k-means的聚类结果和初始聚类中心点的选取有关 C ...

  4. 《PHP面试笔试真题库》——PHP面试的好帮手

    你好,是我琉忆. 一个文艺的PHP开发工程师. 很荣幸能够在这里带来我的第一本新书--<PHP程序员面试笔试真题库>. 一.创作过程 <PHP 程序员面试笔试真题库>是我的第三 ...

  5. 《PHP程序员面试笔试真题解析》——新书上线

    你好,是我--琉忆.很高兴可以跟你分享我的新书. 很高兴,在出版了PHP程序员面试笔试宝典后迎来了我的第二本书出版--<PHP程序员面试笔试真题解析>. 如果你是一个热爱PHP的程序员,刚 ...

  6. 笔试真题解析 ALBB-2015 算法project师实习生机试

    1.用十进制计算30!(30的阶乘),将结果转换成3进制进行表示的话,该进制下的结果末尾会有____个0. [解析] 计算N.下3进制结果末尾有多少个0,事实上就是计算3进制中的3被进位多少次,仅仅要 ...

  7. unity,C#,游戏面试笔试真题

    最开始的两家公司笔试面试题目 一家公司是学校聘请研究教育方面VR课件的公司,面试没几天,就收到了面试通过的消息,后面因为通过了另一家游戏公司而拒绝了. 另一家公司是一家游戏外企,在春熙路,当时笔试还可 ...

  8. 笔试真题解析 ALBB-2015 系统project师研发笔试题

    4)在小端序的机器中,假设 union X {     int x;     char y[4]; }; 假设 X a; a.x=0x11223344;//16进制 则:() y[0]=11 y[1] ...

  9. Java面试中笔试题——Java代码真题,这些题会做,笔试完全可拿下!

    大家好,我是上海尚学堂Java培训老师,以下这些Java笔试真题是上海尚学堂Java学员在找工作中笔试遇到的真题.现在分享出来,也写了参考答案,供大家学习借鉴.想要更多学习资料和视频请留言联系或者上海 ...

  10. PHP+mysql真题

    PHP+mysql真题 来自<PHP程序员面试笔试宝典>,涵盖了近三年了各大型企业常考的PHP面试题,针对面试题提取出来各种面试知识也涵盖在了本书. [真题215] 按要求写出SQL实现. ...

随机推荐

  1. 带你从入门到精通学习WireShark

    个人名片: 因为云计算成为了监控工程师‍ 个人博客:念舒_C.ying CSDN主页️:念舒_C.ying 带你从入门到精通学习WireShark 一.什么是WireShark? 二.WireShar ...

  2. windows error LNK2019

    温馨提示,请使用ctrl+F进行快速查找 ws2_32.lib error LNK2001: 无法解析的外部符号 __imp_htons error LNK2001: 无法解析的外部符号 __imp_ ...

  3. jquery 操作样式

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  4. 【SQL真题】SQL1: 各个视频的平均完播率 【AVG/SUM/IF/CASE】

    题目: https://www.nowcoder.com/practice/96263162f69a48df9d84a93c71045753?tpId=268&tqId=2285032& ...

  5. python安装与初识

    一.Linux基础 - 计算机以及日后我们开发的程序防止的服务器的简单操作 二.Python开发 http://www.cnblogs.com/wupeiqi/articles/5433893.htm ...

  6. Django框架:10、Ajax补充说明、多对多三种创建方法、Django内置序列化组件、批量操作数据方法、分页器思路、form组件

    Django框架 目录 Django框架 一.Ajax补充说明 1.针对前端回调函数接受值的说明 二.多对多三种创建方式 1.自动创建 2.纯手动创建 3.半自动创建 三.Django内置序列化组件 ...

  7. 巧如范金,精比琢玉,一分钟高效打造精美详实的Go语言技术简历(Golang1.18)

    研发少闲月,九月人倍忙.又到了一年一度的"金九银十"秋招季,又到了写简历的时节,如果你还在用传统的Word文档寻找模板,然后默默耕耘,显然就有些落后于时代了,本次我们尝试使用云平台 ...

  8. 红袖添香,绝代妖娆,Ruby语言基础入门教程之Ruby3基础语法,第一次亲密接触EP01

    书接上回,前一篇我们在全平台构建好了Ruby3的开发环境,现在,可以和Ruby3第一次亲密接触了. Ruby是一门在面向对象层面无所不用其极的解释型编程语言. 我们可以把编写Ruby代码看作是一场行为 ...

  9. 90%的Java开发人员都会犯的5个错误

    前言 作为一名java开发程序员,不知道大家有没有遇到过一些匪夷所思的bug.这些错误通常需要您几个小时才能解决.当你找到它们的时候,你可能会默默地骂自己是个傻瓜.是的,这些可笑的bug基本上都是你忽 ...

  10. [深度学习] CCPD车牌数据集介绍

    CCPD是一个大型的.多样化的.经过仔细标注的中国城市车牌开源数据集.CCPD数据集主要分为CCPD2019数据集和CCPD2020(CCPD-Green)数据集.CCPD2019数据集车牌类型仅有普 ...