mysql 查询优化--(分组,函数的应用)例子查找学生-课程成绩低于课程平均分的学生信息

本文主要是介绍mysql 查询优化--(分组,函数的应用)例子查找学生-课程成绩低于课程平均分的学生信息,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

之前上课感觉group by 和 一张表变成两张表使用(类似 from user_class as uc1,user_class as uc2)没怎么学好,特此实验一番

user 表(用户即学生)
这里写图片描述
class表 课程表
这里写图片描述
user_class表 用户选课表
这里写图片描述

查询目的 课程成绩低于课程平均分的学生信息。

第一次尝试,实现简单效果

mysql> select uc.* from user_class as uc 
where uc.grade < (select avg(grade) from user_class as uc2 where uc2.c_id = uc.c_id);

显示效果:
查询到了需要的数据,找到了比平均分低的学生信息,这个sql只用到了两张虚拟表提供查询学生成绩和平均成绩作为对比。
这里写图片描述

第二次尝试现在需要把平均成绩显示出来

mysql> select uc.*,
(select avg(grade) from user_class as uc2 where uc2.c_id = uc.c_id) as avg_grade 
from user_class as uc 
where uc.grade < (select avg(grade) as avg_grade from user_class as uc2 where uc2.c_id = uc.c_id);

显示效果
虽然sql比较冗余,但是效果出来了。 想办法优化
这里写图片描述

第三次尝试通过之前的方法无法实现优化,现在换种思路

mysql> select uc.*,my.* from user_class as uc, 
(select c_id,avg(grade)  from user_class as uc group by uc.c_id) as my 
where uc.c_id = my.c_id ;

这里写图片描述

第四次尝试,实现简单显示优化

mysql> select uc.*,my.avg_grade from user_class as uc, 
(select c_id,avg(grade) as avg_grade from user_class as uc 
group by uc.c_id) as my 
where uc.c_id = my.c_id and uc.grade < my.avg_grade ;

这里写图片描述

最终显示效果优化

mysql> select user.name,uc.*,my.avg_grade,my.num as '选课人数' 
from user_class as uc,user , 
(select c_id,avg(grade) as avg_grade,count(grade) as num from user_class as uc group by uc.c_id) as my 
where uc.u_id = user.id and uc.c_id = my.c_id 
and uc.grade < my.avg_grade ;

这里写图片描述

主要用到的小功能是 ,一个user_class表在一个sql中可以起两次别名,uc1和uc2 一个用作查询用户信息,一个用作查询平均成绩使用,功能分离,还有就是avg和count函数的使用,相对简单,一开始那个冗余的sql 还是不要用了。

这篇关于mysql 查询优化--(分组,函数的应用)例子查找学生-课程成绩低于课程平均分的学生信息的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/388521

相关文章

SpringBoot3实现Gzip压缩优化的技术指南

《SpringBoot3实现Gzip压缩优化的技术指南》随着Web应用的用户量和数据量增加,网络带宽和页面加载速度逐渐成为瓶颈,为了减少数据传输量,提高用户体验,我们可以使用Gzip压缩HTTP响应,... 目录1、简述2、配置2.1 添加依赖2.2 配置 Gzip 压缩3、服务端应用4、前端应用4.1 N

Kotlin 作用域函数apply、let、run、with、also使用指南

《Kotlin作用域函数apply、let、run、with、also使用指南》在Kotlin开发中,作用域函数(ScopeFunctions)是一组能让代码更简洁、更函数式的高阶函数,本文将... 目录一、引言:为什么需要作用域函数?二、作用域函China编程数详解1. apply:对象配置的 “流式构建器”最

MySQL双主搭建+keepalived高可用的实现

《MySQL双主搭建+keepalived高可用的实现》本文主要介绍了MySQL双主搭建+keepalived高可用的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,... 目录一、测试环境准备二、主从搭建1.创建复制用户2.创建复制关系3.开启复制,确认复制是否成功4.同

Spring Boot + MyBatis Plus 高效开发实战从入门到进阶优化(推荐)

《SpringBoot+MyBatisPlus高效开发实战从入门到进阶优化(推荐)》本文将详细介绍SpringBoot+MyBatisPlus的完整开发流程,并深入剖析分页查询、批量操作、动... 目录Spring Boot + MyBATis Plus 高效开发实战:从入门到进阶优化1. MyBatis

MyBatis 动态 SQL 优化之标签的实战与技巧(常见用法)

《MyBatis动态SQL优化之标签的实战与技巧(常见用法)》本文通过详细的示例和实际应用场景,介绍了如何有效利用这些标签来优化MyBatis配置,提升开发效率,确保SQL的高效执行和安全性,感... 目录动态SQL详解一、动态SQL的核心概念1.1 什么是动态SQL?1.2 动态SQL的优点1.3 动态S

Mysql表的简单操作(基本技能)

《Mysql表的简单操作(基本技能)》在数据库中,表的操作主要包括表的创建、查看、修改、删除等,了解如何操作这些表是数据库管理和开发的基本技能,本文给大家介绍Mysql表的简单操作,感兴趣的朋友一起看... 目录3.1 创建表 3.2 查看表结构3.3 修改表3.4 实践案例:修改表在数据库中,表的操作主要

Python如何使用__slots__实现节省内存和性能优化

《Python如何使用__slots__实现节省内存和性能优化》你有想过,一个小小的__slots__能让你的Python类内存消耗直接减半吗,没错,今天咱们要聊的就是这个让人眼前一亮的技巧,感兴趣的... 目录背景:内存吃得满满的类__slots__:你的内存管理小助手举个大概的例子:看看效果如何?1.

Python中随机休眠技术原理与应用详解

《Python中随机休眠技术原理与应用详解》在编程中,让程序暂停执行特定时间是常见需求,当需要引入不确定性时,随机休眠就成为关键技巧,下面我们就来看看Python中随机休眠技术的具体实现与应用吧... 目录引言一、实现原理与基础方法1.1 核心函数解析1.2 基础实现模板1.3 整数版实现二、典型应用场景2

一文详解SpringBoot响应压缩功能的配置与优化

《一文详解SpringBoot响应压缩功能的配置与优化》SpringBoot的响应压缩功能基于智能协商机制,需同时满足很多条件,本文主要为大家详细介绍了SpringBoot响应压缩功能的配置与优化,需... 目录一、核心工作机制1.1 自动协商触发条件1.2 压缩处理流程二、配置方案详解2.1 基础YAML

mysql出现ERROR 2003 (HY000): Can‘t connect to MySQL server on ‘localhost‘ (10061)的解决方法

《mysql出现ERROR2003(HY000):Can‘tconnecttoMySQLserveron‘localhost‘(10061)的解决方法》本文主要介绍了mysql出现... 目录前言:第一步:第二步:第三步:总结:前言:当你想通过命令窗口想打开mysql时候发现提http://www.cpp