【MySQL】多表联合查询常见练习题

news2024/11/17 5:35:32

数据库表如下:   

        teacher:老师表

        course:课程表

        student:学生表

        class:班级表

        sc:成绩表

一、根据上面5张表写sql语句

1. 查询” 01 “课程比” 02 “课程成绩高的学生的信息及课程分数

select student.*,t1.score 课程1分数,t2.score 课程2分数 from student

inner join (select * from sc where cid=1) t1 on student.sid=t1.sid

inner join (select * from sc where cid=2) t2 on t1.sid=t2.sid

where t1.score>t2.score;

2. 查询平均成绩大于等于 60 分的同学的学生编号和学生姓名和平均成绩

select student.sid,sname,avg(score) from student

left join sc on student.sid=sc.sid

group by student.sid

having avg(score)>=60;
select student.sid,sname,avg(score) from sc,student

where student.sid=sc.sid

group by student.sid

having avg(score)>=60;

3. 查询在 SC 表存在成绩的学生信息

select * from student where sid in

(select sid from sc);
select distinct student.* from student

inner join sc on student.sid=sc.sid ;

4. 查询所有同学的学生编号、学生姓名、选课总数、所有课程的总成绩(没成绩的显示为 null )

select student.sid,sname,count(cid),sum(score) from student

left join sc on student.sid=sc.sid

group by student.sid;

5. 查询「李」姓老师的数量

select count(*) from teacher where tname like '李%';

6. 查询学过「张三」老师授课的同学的信息

select * from student where student.sid in(

select sid from sc where sc.cid =(

select cid from course where course.tid=(

select tid from teacher where tname='张三'

)

    )

);

7. 查询没有学全所有课程的同学的信息

select student.*,count(cid) from student

left join sc on student.sid=sc.sid

group by student.sid

having count(cid)<(select count(*) from course);

8. 查询至少有一门课与学号为” 01 “的同学所学相同的同学的信息

select distinct student.* from student

left join sc on student.sid=sc.sid

where cid in(

    select cid from sc where sid=1 and student.sid != 1

);

9. 查询和” 01 “号的同学学习的课程完全相同的其他同学的

    注意:一模一样 1.范围相同 2.个数相同

select student.* from  student

inner join sc on student.sid=sc.sid

where student.sid not in                          -- 范围(逆向)

    (select sid from sc where cid not in

       (select cid from sc where sid=1)

    )

and student.sid != 1

group by student.sid

having count(cid)=(select count(*) from sc where sid=1);  -- 个数相同

10. 查询没学过”张三”老师讲授的任一门课程的学生姓名

select sname from student where student.sid not in

    (select sid from sc where sc.cid =

       (select cid from course where course.tid =

           (select tid from teacher where tname='张三')

    )

  )

11. 查询两门及其以上不及格课程的同学的学号,姓名及其平均成绩

select student.sid,sname,avg(score) from sc,student

where score<60 and sc.sid=student.sid

group by student.sid

having count(cid)>=2;

12. 检索” 01 “课程分数小于 60,按分数降序排列的学生信息

select * from student,sc

where student.sid=sc.sid and cid=1 and score<60

order by score desc

13. 查询各科成绩最高分、最低分和平均分,以如下形式显示:课程 ID,课程 name,最高分,最低分,平均分,及格率,中等率,优良率,优秀率(及格为>=60,中等为:70-80,优良为:80-90,优秀为:>=90)

select sc.cid,cname,max(score),min(score),avg(score),

    count(case when score >=60 then score end)/count(*) * 100 及格率,

    count(case when score >=70 and score <80 then score end)/count(*) * 100 中等率,

    count(case when score >=80 and score <90 then score end)/count(*) * 100 优良率,

    count(case when score >90 then score end)/count(*) * 100 优秀率

from course,sc

where course.cid=sc.cid

group by course.cid

-- 各科成绩最高分、最低分和平均分
select sc.cid,cname,max(score),min(score),avg(score) from course,sc

where course.cid=sc.cid

group by course.cid

-- 及格率,中等率,优良率,优秀率
select cid,

    count(case when score >=60 then score end)/count(*) * 100,

    count(case when score >=70 and score <80 then score end)/count(*) * 100,

    count(case when score >=80 and score <90 then score end)/count(*) * 100,

    count(case when score >90 then score end)/count(*) * 100

from sc

group by cid

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

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

相关文章

AI智能时代的图书馆未来,你想象过吗!

AI智能时代的图书馆未来&#xff0c;你想象过吗&#xff01; 前言AI智能时代的图书馆未来 前言 教育数字化和 AI 时代的浪潮正汹涌而来&#xff0c;图书馆也站在了变革的十字路口。我们看到高等教育正在发生深刻的变革&#xff0c;从教学模式到人才培养理念&#xff0c;都在经…

基于SSM+VUE的学生宿舍管理系统

文未可获取一份本项目的java源码和数据库参考。 随着社会经济的迅速发展和科学技术的全面进步&#xff0c;计算机事业的飞速发展&#xff0c;以计算机与通信技术为基础的信息系统正处于蓬勃发展的时期&#xff0c;当今社会正快速向数字化&#xff0c;信息化&#xff0c;网络化…

VSCode开发Vue3+TS项目中遇到各种波浪线(诊断信息)

一、问题汇总 在使用Visual Studio Code&#xff08;VSCode&#xff09;开发Vue3 TypeScript项目时&#xff0c;会遇到各种波浪线错误&#xff08;诊断信息&#xff09;&#xff0c;这些问题或错误通常由以下几人原因引起的&#xff1a; 1.1 常见问题 1、typeScript配置问题…

【探索 GDB 和 CGDB】:强大的调试工具介绍

&#x1f4c3;个人主页&#xff1a;island1314 &#x1f525;个人专栏&#xff1a;Linux—登神长阶 ⛺️ 欢迎关注&#xff1a;&#x1f44d;点赞 &#x1f442;&#x1f3fd;留言 &#x1f60d;收藏 &#x1f49e; &#x1f49e; &#x1f49e; 1. 引言&#x1f4c3; 1.1 …

Kotlin:1.8.0 的新特性

一、概述 Kotlin 1.8.0版本英语官方文档 Kotlin 1.8.0 中文官方文档 The Kotlin 1.8.0 release is out and here are some of its biggest highlights: Kotlin 1.8.0发布了&#xff0c;下面是它的一些亮点: JVM 平台新增实验性函数&#xff1a;递归复制或删除目录内容改进了 …

SpringMVC——REST

路径请求方式请求行为 查询&#xff1a;GET 新增&#xff1a;POST 修改&#xff1a;PUT 删除&#xff1a;DELETE 有重复的东西怎么办

第L6周:机器学习|支持向量机(SVM):2. 支持向量机实战

本文为365天深度学习训练营 中的学习记录博客原作者&#xff1a;K同学啊 这里展示一下怎么调用scikit-learn库实现线性SVM&#xff0c;知道怎么调用扩展一下知识面就OK了。 1.scikit-learn库实现线性可分的SVM from sklearn import datasets from sklearn.model_selection im…

聊聊光刻工序常见术语(2)

上次&#xff0c;我们总结了光刻工序部分的术语&#xff0c;见文章&#xff1a; 《光刻工序常见术语中英文对照&#xff08;1&#xff09;》 这次&#xff0c;我们把剩下的又总结了一些&#xff0c;供大家参阅。 1&#xff0c;Developer Mist&#xff1a;显影液回溅产生的水…

计算机毕业设计 基于SpringBoot和Vue的课程教学平台的设计与实现 Java实战项目 附源码+文档+视频讲解

博主介绍&#xff1a;✌从事软件开发10年之余&#xff0c;专注于Java技术领域、Python人工智能及数据挖掘、小程序项目开发和Android项目开发等。CSDN、掘金、华为云、InfoQ、阿里云等平台优质作者✌ &#x1f345;文末获取源码联系&#x1f345; &#x1f447;&#x1f3fb; 精…

STM32(五)GPIO输入硬件电路及C语言知识复习

本小节主要是GPIO输入模式下的硬件电路和C语言知识的回顾 C语言中的数据&#xff1a;定义和引用 一、GPIO输入模式下的硬件和电路 1.按键介绍 可以用延时函数消除按键抖动 2.传感器模块介绍 &#xff08;1&#xff09;传感器元件的电阻会随模拟量的变化而变化&#xff0c;通…

【算法】链表:206.反转链表(easy)

系列专栏 《分治》 《模拟》 《Linux》 目录 1、题目链接 2、题目介绍 3、解法&#xff08;快慢指针&#xff09; 解题步骤&#xff1a; 关键点&#xff1a; 复杂度分析&#xff1a; 4、代码 1、题目链接 206. 反转链表 - 力扣&#xff08;LeetCode&#xff09; …

通信工程学习:什么是SMTP简单邮件传输协议

SMTP&#xff1a;简单邮件传输协议 SMTP&#xff08;Simple Mail Transfer Protocol&#xff09;&#xff0c;即简单邮件传输协议&#xff0c;是用于电子邮件传输的标准协议。它定义了电子邮件在互联网上的传输方式&#xff0c;以及邮件服务器之间的通信方式。以下是对SMTP协议…

Stream流的初步认识,Stream流的思想和获取Stream流

一.Stream流的作用 package com.njau.my_stream;import java.util.ArrayList;/*** 目标&#xff1a;认识Stream流* 案例&#xff1a;将以“张”开头的人名筛选出来到一个新的集合中去&#xff0c;再将其中三个字的名字的筛选出来到新集合中去*/ public class StreamDemo1 {pub…

【算法竞赛】算法复杂度

计算的资源是有限的,竞赛题会限制代码所使用的计算资源。 计算资源有两种:计算时间和存储空间。与此对应的有时间复杂度和空间复杂度,时间复杂度衡量计算的次数,空间复杂度衡量需要的存储空间。 编程竞赛的题目在逻辑、数学、算法上有不同的难度:简单的题目,可以一眼看懂;复 …

1.8 物理层下的传输媒体

欢迎大家订阅【计算机网络】学习专栏&#xff0c;开启你的计算机网络学习之旅&#xff01; 文章目录 1 导引型传输媒体1.1 双绞线1.2 同轴电缆1.3 光缆 2 非导引型传输媒体2.1 无线电微波通信2.2 多径效应2.3 卫星通信2.4 无线局域网 在数据通信系统中&#xff0c;传输媒体是发…

排水系统C++

题目&#xff1a; 样例解释&#xff1a; 1 号结点是接收口&#xff0c;4,5 号结点没有排出管道&#xff0c;因此是最终排水口。 1 吨污水流入 1 号结点后&#xff0c;均等地流向 2,3,5 号结点&#xff0c;三个结点各流入 1/3 吨污水。 2 号结点流入的 1/3​ 吨污水将均等地流向…

【Nacos 架构 原理】服务发现模块之Nacos注册中心服务数据模型

文章目录 服务&#xff08;Service&#xff09;和服务实例&#xff08;Instance&#xff09;定义服务服务元数据定义实例实例元数据持久化属性 集群定义集群 生命周期服务的生命周期实例的生命周期集群的生命周期元数据的生命周期 服务&#xff08;Service&#xff09;和服务实…

vue3中el-input在form表单按下回车刷新页面

摘要&#xff1a; 在input框中点击回车之后不是调用我写的回车事件&#xff0c;而是刷新页面&#xff01; 如果表单中只有一个input 框则按下回车会直接关闭表单 所以导致刷新页面 再写一个input 表单 &#xff0c;并设置style“display:none” <ElInput style"display…

畅阅读小程序|畅阅读系统|基于java的畅阅读系统小程序设计与实现(源码+数据库+文档)

畅阅读系统小程序 目录 基于java的畅阅读系统小程序设计与实现 一、前言 二、系统功能设计 三、系统实现 四、数据库设计 1、实体ER图 五、核心代码 六、论文参考 七、最新计算机毕设选题推荐 八、源码获取&#xff1a; 博主介绍&#xff1a;✌️大厂码农|毕设布道师…

用C语言实现通讯录(顺序表实现)

SeqList.h 顺序表的头文件 #include <stdio.h> #include <stdlib.h> #include <assert.h> #include <string.h> #include "Contact.h" typedef PerInfo SLDatatype;//PerInfo为结构体类型//动态顺序表 typedef struct SeqList {SLDatatype…