当前位置: 首页 > news >正文

SQL,HQL刷题,尚硅谷

相关表数据:

1、score_info

2、student_info

题目及思路解析:

分组结果的条件

   1、查询平均成绩大于60分的学生的学号和平均成绩

代码:

selectstu_id,avg(score) score_avg
from score_info
group by stu_id
having score_avg>60;

思路解析:

首先通过学号进行分组,获取到每个学习的所有科目的成绩,接着求平均成绩(所有学科总成绩的平均成绩),最后对求得的平均成绩进行条件筛选,得到符合题目要求的学生信息

结果:

 

   2、查询至少选修四门课程的学生学号

代码:

selectstu_id
from score_info
group by stu_id
having count(course_id)>=4;

selectstu_id,count(course_id) course_count
from score_info
group by stu_id
having course_count >=4;

思路解析: 

首先对学号进行分组,获取到每个学生的参加考试学科的成绩信息,用count函数对学科号进行统计,并按照题目条件进行筛选,最终获取符合题意的学生成绩信息

结果:

   3、查询同姓(假设每个学生姓名的第一个字为姓)的学生名单并统计同姓人数大于2的姓

注:本题可以使用字符串函数substring()

代码:

selectt1.first_name,count(*) first_name_count
from
(selectstu_id,substring(stu_name,0,1) first_namefrom student_info
)t1
group by t1.first_name
having first_name_count >=2;

注:

1、第二层查询可以不用t1.first_name

2、count(*)即统计表中所有行数,包括null    (也可以使用count(列名),不包括null)

3、关于subtring补充请点击跳转--->  知识补充

思路解析:  

首先我们利用substring()函数获取到每个学生的姓氏,接着我们对获取的姓氏进行分组、并统计分组后的人数,最后按照题目要求进行筛选,获取到符合题意的学生信息

结果: 

   4、查询每门课程的平均成绩,结果按平均成绩升序排序,平均成绩相同时,按课程号降序排列

 代码:

selectcourse_id,avg(score) avg_score
from score_info
group by course_id
order by avg_score asc,course_id desc ;

注: 平均成绩升序按排序,后面加上按课程号降序排列,即平均成绩相同时自动按照第二种排序情况

思路解析: 

首先对课程号进行分组(获取到每个课程的学生成绩),对获取的课程成绩(总成绩)求平均值,最后对结果进行排序,平均成绩按升序,平均成绩相同时,按课程号降序排列 。

结果:

   5、统计参加考试人数大于等于15的学科

 代码:

selectcourse_id,count(*) number_test
from score_info
group by course_id
having number_test>=15;

思路解析: 

首先按照课程号进行分组,接着统计每个课程的参加考试人数,然后添加条件进行进一步筛选,最终获取到符合题意的数据。

结果:

总结归纳: 

考察了聚合函数与分组聚合的综合运用,使用了字符串函数,查询简单嵌套等

知识补充:

substring:截取字符串

    语法一:substring(string A, int start)

    返回值:string

    说明:返回字符串A   从start位置到结尾的字符串

    语法二:substring(string A, int start, int len)

    返回值:string

    说明:返回字符串A从start位置开始,长度为len的字符串

http://www.lryc.cn/news/298999.html

相关文章:

  • DevOps:CI、CD、CB、CT、CD
  • [leetcode经典算法题]删除有序数组中的重复项(双指针)
  • 【国产MCU】-CH32V307-触摸按键检测(TKEY)
  • Hive的小文件问题
  • 攻防世界——re2-cpp-is-awesome
  • 问山海——天涯海角——桃花渊boss攻击顺序
  • springboot181基于springboot的乐享田园系统
  • Dubbo集成Zookeeper embbed模式
  • 156基于Matlab的光纤陀螺随机噪声和信号
  • 秋招上岸大厂,分享一下经验
  • 使用 C++23 从零实现 RISC-V 模拟器
  • Hugging Face 刚刚推出了一款开源的 AI 助手制造工具,直接向 OpenAI 的定制 GPT 挑战
  • powershell 雅地关闭UDP监听器
  • Google Cloud 2024 年报告重点介绍了关键的网络威胁和防御
  • 【算法题】102. 二叉树的层序遍历
  • 【龙年大礼】| 2023中国开源年度报告!
  • 本地搭建three.js官方文档
  • 【seata自动化治愈数据库问题解决方案】
  • Node.js之npm单独与批量升级依赖包的方式
  • 66.加一
  • UI自动化之Poco常用断言方式
  • c语言_实现类class的功能 实例
  • [2024]常用的pip指令
  • 【Java EE初阶十二】网络编程TCP/IP协议(二)
  • Idea Git Review插件
  • python的turtle可以定义多个海龟对象
  • LocalAI 部署(主要针对 mac m2 启动)
  • Swift Combine 管道 从入门到精通三
  • 【RISC-V DSP设计】基于CEVA DSP架构的指令集分析(二)-函数列表
  • 蓝桥杯(Web大学组)2022国赛真题:水果消消乐