sql之每日五题day01--多表联查/聚合函数

2024-03-31 22:28

本文主要是介绍sql之每日五题day01--多表联查/聚合函数,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

sql错题记录

    • 含有聚合函数的不能用where
    • 升序排列order by
    • left join多表联查
    • inner join不返回null
    • 三表联查

含有聚合函数的不能用where

  • SQL19 分组过滤练习题

题目:现在运营想查看每个学校用户的平均发贴和回帖情况,寻找低活跃度学校进行重点运营,请取出平均发贴数低于5的学校或平均回帖数小于20的学校。

在这里插入图片描述

select university,	avg(question_cnt) as avg_question_cnt,	avg(answer_cnt) as avg_answer_cnt
from user_profile
group by university
having avg_question_cnt <5 or avg_answer_cnt <20
# where avg_question_cnt <5 or avg_answer_cnt <20

升序排列order by

  • SQL20 分组排序练习题

现在运营想要查看不同大学的用户平均发帖情况,并期望结果按照平均发帖情况进行升序排列,请你取出相应数据。

在这里插入图片描述

  • 默认是升序
-- 按照某一列升序排序
SELECT column1, column2
FROM table_name
ORDER BY column1 ASC;-- 按照某一列降序排序
SELECT column1, column2
FROM table_name
ORDER BY column1 DESC;
select university,	avg(question_cnt) as avg_question_cnt
from user_profile
group by university
order by avg_question_cnt

left join多表联查

  • SQL21 浙江大学用户题目回答情况

现在运营想要查看所有来自浙江大学的用户题目回答明细情况,请你取出相应数据

在这里插入图片描述

所以,在 LEFT JOIN 中,左边的表是指在 FROM 子句中出现在 LEFT JOIN 关键字之前的那个表,而右边的表则是在 LEFT JOIN 关键字之后的表。左表是主表,右表是从表。

SELECT *
FROM 左表
LEFT JOIN 右表 ON 左表.列名 = 右表.列名;
select up.device_id,qpd.question_id,qpd.result
from user_profile as up
left join question_practice_detail as qpd on up.device_id=qpd.device_id
where university='浙江大学'
order by qpd.question_id

inner join不返回null

  • SQL22 统计每个学校的答过题的用户的平均答题数

运营想要了解每个学校答过题的用户平均答题数量情况,请你取出数据。

在这里插入图片描述

select up.university,	count(question_id) / count(distinct up.device_id) as avg_answer_cnt
from user_profile as up
inner join question_practice_detail as qpd on up.device_id=qpd.device_id
group by up.university

三表联查

  • SQL23 统计每个学校各难度的用户平均刷题数

运营想要计算一些参加了答题的不同学校、不同难度的用户平均答题量,请你写SQL取出相应数据

在这里插入图片描述

select up.university,	qd.difficult_level,round(count(qpd.question_id)/count(distinct qpd.device_id),4) as avg_answer_cnt
from question_practice_detail as qpd
left join user_profile as up  on  up.device_id=qpd.device_id
left join question_detail as qd on qd.question_id=qpd.question_id
group by university,difficult_level

细节问题:
表头重命名:as
平均值精度:保留4位小数round(x, 4)

这篇关于sql之每日五题day01--多表联查/聚合函数的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

MySQL数据库双机热备的配置方法详解

《MySQL数据库双机热备的配置方法详解》在企业级应用中,数据库的高可用性和数据的安全性是至关重要的,MySQL作为最流行的开源关系型数据库管理系统之一,提供了多种方式来实现高可用性,其中双机热备(M... 目录1. 环境准备1.1 安装mysql1.2 配置MySQL1.2.1 主服务器配置1.2.2 从

Python函数作用域与闭包举例深度解析

《Python函数作用域与闭包举例深度解析》Python函数的作用域规则和闭包是编程中的关键概念,它们决定了变量的访问和生命周期,:本文主要介绍Python函数作用域与闭包的相关资料,文中通过代码... 目录1. 基础作用域访问示例1:访问全局变量示例2:访问外层函数变量2. 闭包基础示例3:简单闭包示例4

深入理解Mysql OnlineDDL的算法

《深入理解MysqlOnlineDDL的算法》本文主要介绍了讲解MysqlOnlineDDL的算法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小... 目录一、Online DDL 是什么?二、Online DDL 的三种主要算法2.1COPY(复制法)

mysql8.0.43使用InnoDB Cluster配置主从复制

《mysql8.0.43使用InnoDBCluster配置主从复制》本文主要介绍了mysql8.0.43使用InnoDBCluster配置主从复制,文中通过示例代码介绍的非常详细,对大家的学习或者... 目录1、配置Hosts解析(所有服务器都要执行)2、安装mysql shell(所有服务器都要执行)3、

k8s中实现mysql主备过程详解

《k8s中实现mysql主备过程详解》文章讲解了在K8s中使用StatefulSet部署MySQL主备架构,包含NFS安装、storageClass配置、MySQL部署及同步检查步骤,确保主备数据一致... 目录一、k8s中实现mysql主备1.1 环境信息1.2 部署nfs-provisioner1.2.

MySQL中VARCHAR和TEXT的区别小结

《MySQL中VARCHAR和TEXT的区别小结》MySQL中VARCHAR和TEXT用于存储字符串,VARCHAR可变长度存储在行内,适合短文本;TEXT存储在溢出页,适合大文本,下面就来具体的了解... 目录一、VARCHAR 和 TEXT 基本介绍1. VARCHAR2. TEXT二、VARCHAR

MySQL中C接口的实现

《MySQL中C接口的实现》本节内容介绍使用C/C++访问数据库,包括对数据库的增删查改操作,主要是学习一些接口的调用,具有一定的参考价值,感兴趣的可以了解一下... 目录准备mysql库使用mysql库编译文件官方API文档对象的创建和关闭链接数据库下达sql指令select语句前言:本节内容介绍使用C/

mybatis直接执行完整sql及踩坑解决

《mybatis直接执行完整sql及踩坑解决》MyBatis可通过select标签执行动态SQL,DQL用ListLinkedHashMap接收结果,DML用int处理,注意防御SQL注入,优先使用#... 目录myBATiFBNZQs直接执行完整sql及踩坑select语句采用count、insert、u

MySQL之搜索引擎使用解读

《MySQL之搜索引擎使用解读》MySQL存储引擎是数据存储和管理的核心组件,不同引擎(如InnoDB、MyISAM)采用不同机制,InnoDB支持事务与行锁,适合高并发场景;MyISAM不支持事务,... 目录mysql的存储引擎是什么MySQL存储引擎的功能MySQL的存储引擎的分类查看存储引擎1.命令

Python中isinstance()函数原理解释及详细用法示例

《Python中isinstance()函数原理解释及详细用法示例》isinstance()是Python内置的一个非常有用的函数,用于检查一个对象是否属于指定的类型或类型元组中的某一个类型,它是Py... 目录python中isinstance()函数原理解释及详细用法指南一、isinstance()函数