left join 使用 sum()

2024-08-28 17:28
文章标签 使用 join sum left

本文主要是介绍left join 使用 sum(),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一,表结构

表一,test_group 分组表
在这里插入图片描述
表二,test_user 用户表
在这里插入图片描述
test_group 和 test_user 是一对多的关系

二,sql

  1. 统计一班的总得分和所有用户的总年龄
SELECT SUM(a.score),SUM(b.age),a.groupname from test_group a LEFT JOIN test_user b on a.id=b.group_id where a.id=1

在这里插入图片描述
会发现 一班的 score 不对,翻了4倍。要解释这个问题需要先弄懂 left join。
例如:

1.   SELECT * from test_group a LEFT JOIN test_user b on a.id=b.group_id;

在这里插入图片描述

2.   SELECT * from test_group a LEFT JOIN test_user b on a.id=b.group_id where b.sex=1;

在这里插入图片描述

 1.   SELECT * from test_group a LEFT JOIN test_user b on a.id=b.group_id and b.sex=1;

在这里插入图片描述

left join 首先 根据 on 条件组成一个临时表
on 条件可以有多个,on条件是在组成临时表前对 右表的筛选
where 条件是对 组成好的临时表进行筛选,不符合条件的直接筛选掉

语句2中where 条件 sex=1,从临时表中去掉不符合条件的数据
语句3中 on 多个条件,先对右表筛选 sex=1,再生成临时表。左表没有的数据以null补齐,以右表为主。

  1. sum数据不对的问题
SELECT * from test_group a LEFT JOIN test_user b on a.id=b.group_id where a.id=1;

在这里插入图片描述

 SELECT SUM(a.score),SUM(b.age),a.groupname from test_group a LEFT JOIN test_user b on a.id=b.group_id where a.id=1;

一对多,实际上是对上面四条数据的 sum(a.score)。

  1. 正确的写法
SELECT SUM(DISTINCT a.score),SUM(b.age),a.groupname from test_group a LEFT JOIN test_user b on a.id=b.group_id where a.id=1;

因为查询后的每个 group中的score都一样,可以使用 distinct 去重。SUM DISTINCT只能用于单个列的求和,不能用于多个列的求和

SELECT SUM(a.score),SUM(b.age2),a.groupname from test_group a LEFT JOIN (select id,group_id,SUM(age) age2 from test_user GROUP BY group_id) bon a.id=b.group_id where a.id=1

避免直接lefj join 查询,先查询子表,再将子表查询结果与主表结果关联
先处理“一对多”中这个多表,将多表中的数据先聚合成一条
再和 左表连接查询

这篇关于left join 使用 sum()的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Mybatis官方生成器的使用方式

《Mybatis官方生成器的使用方式》本文详细介绍了MyBatisGenerator(MBG)的使用方法,通过实际代码示例展示了如何配置Maven插件来自动化生成MyBatis项目所需的实体类、Map... 目录1. MyBATis Generator 简介2. MyBatis Generator 的功能3

Python中使用defaultdict和Counter的方法

《Python中使用defaultdict和Counter的方法》本文深入探讨了Python中的两个强大工具——defaultdict和Counter,并详细介绍了它们的工作原理、应用场景以及在实际编... 目录引言defaultdict的深入应用什么是defaultdictdefaultdict的工作原理

使用Python进行文件读写操作的基本方法

《使用Python进行文件读写操作的基本方法》今天的内容来介绍Python中进行文件读写操作的方法,这在学习Python时是必不可少的技术点,希望可以帮助到正在学习python的小伙伴,以下是Pyth... 目录一、文件读取:二、文件写入:三、文件追加:四、文件读写的二进制模式:五、使用 json 模块读写

Python使用qrcode库实现生成二维码的操作指南

《Python使用qrcode库实现生成二维码的操作指南》二维码是一种广泛使用的二维条码,因其高效的数据存储能力和易于扫描的特点,广泛应用于支付、身份验证、营销推广等领域,Pythonqrcode库是... 目录一、安装 python qrcode 库二、基本使用方法1. 生成简单二维码2. 生成带 Log

Python如何使用seleniumwire接管Chrome查看控制台中参数

《Python如何使用seleniumwire接管Chrome查看控制台中参数》文章介绍了如何使用Python的seleniumwire库来接管Chrome浏览器,并通过控制台查看接口参数,本文给大家... 1、cmd打开控制台,启动谷歌并制定端口号,找不到文件的加环境变量chrome.exe --rem

Oracle数据库使用 listagg去重删除重复数据的方法汇总

《Oracle数据库使用listagg去重删除重复数据的方法汇总》文章介绍了在Oracle数据库中使用LISTAGG和XMLAGG函数进行字符串聚合并去重的方法,包括去重聚合、使用XML解析和CLO... 目录案例表第一种:使用wm_concat() + distinct去重聚合第二种:使用listagg,

使用C#代码计算数学表达式实例

《使用C#代码计算数学表达式实例》这段文字主要讲述了如何使用C#语言来计算数学表达式,该程序通过使用Dictionary保存变量,定义了运算符优先级,并实现了EvaluateExpression方法来... 目录C#代码计算数学表达式该方法很长,因此我将分段描述下面的代码片段显示了下一步以下代码显示该方法如

Go语言使用Buffer实现高性能处理字节和字符

《Go语言使用Buffer实现高性能处理字节和字符》在Go中,bytes.Buffer是一个非常高效的类型,用于处理字节数据的读写操作,本文将详细介绍一下如何使用Buffer实现高性能处理字节和... 目录1. bytes.Buffer 的基本用法1.1. 创建和初始化 Buffer1.2. 使用 Writ

redis-cli命令行工具的使用小结

《redis-cli命令行工具的使用小结》redis-cli是Redis的命令行客户端,支持多种参数用于连接、操作和管理Redis数据库,本文给大家介绍redis-cli命令行工具的使用小结,感兴趣的... 目录基本连接参数基本连接方式连接远程服务器带密码连接操作与格式参数-r参数重复执行命令-i参数指定命

PyTorch使用教程之Tensor包详解

《PyTorch使用教程之Tensor包详解》这篇文章介绍了PyTorch中的张量(Tensor)数据结构,包括张量的数据类型、初始化、常用操作、属性等,张量是PyTorch框架中的核心数据结构,支持... 目录1、张量Tensor2、数据类型3、初始化(构造张量)4、常用操作5、常用属性5.1 存储(st