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

【MySQL】解决在join表时一对多的情况下重复数据的问题

在MySQL中进行JOIN操作,特别是在处理一对多关系的表时,可能会出现重复的记录,这是因为左表(或右表)中的每一项在与右表(或左表)连接时,如果对应有多条匹配记录,则会生成多次组合。

一般的业务场景,使用DISTINCTGROUP BY往往都能够实现,这里主要说一种比较取巧的方法:

-- 假设a表跟b表的关系是多对一
SELECT SUM(b.amount) / COUNT(DISTINCT a.id)
FROM table_a a LEFT JOIN table_b b ON b.a_id = a.id;

不难看出,关键点在于/ COUNT(DISTINCT a.id),这里直接除掉去重后的a表数,最后得到的结果就是准确的,也不需要再额外使用子查询或是其他聚合操作。

最后说明一下,以上例子是在SQL本身已经非常复杂并且无法再进行DISTINCT或是GROUP BY的情况下针对单列数据聚合使用的,一般的业务场景直接使用DISTINCTGROUP BY即可。

如果有更好的实现方式欢迎各位在评论区交流。

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

相关文章:

  • 高并发Server的基石:reactor反应堆模式
  • Linux安全基线与加固
  • 应对电脑重新分区文件消失:预防措施、常见成因与恢复关键要点
  • 本地配置多个git账户及ll设置
  • week04day04(爬虫)
  • 【数据结构初阶 6】二叉树:堆的基本操作 + 堆排序的实现
  • IDEA Debug框的 show execution point按钮没了
  • 突破编程_C++_面试(类(1))
  • vue项目使用vue2-org-tree
  • Vue30 自定义指令 函数式 对象式
  • JAVA高并发——单例模式和不变模式
  • RabbitMQ(一):消息队列MQ
  • HarmonyOS—使用预览器查看应用/服务效果
  • 大项目中,某个cpp文件读取所在包路径的方法
  • gem5学习(25):用于异构SoC的片上网络模型——Garnet2.0
  • 康威生命游戏
  • vscode与vue环境配置
  • Linux的ACL权限以及特殊位和隐藏属性
  • 使用openai-whisper实现语音转文字
  • C++模板为什么不能声明和定义分离
  • 啊丢的刷题记录手册
  • 用nginx正向代理https网站
  • 面向对象设计模式
  • 人工智能_CPU微调ChatGLM大模型_使用P-Tuning v2进行大模型微调_007_微调_002---人工智能工作笔记0102
  • Android自编译Pixel3内核加入KernelSU
  • Go 数据库编程精粹:database/sql 实用技巧解析
  • AI-Gateway:一款整合了OpenAI、Anthropic、LLama2等大语言模型的统一API接口
  • Android 广播的基本概念
  • 【Docker实操】部署php项目
  • 多线程-初阶