记录一次巧妙的SQL:一对多关联导致的 sum () 、count()等group函数重复计算问题

1.问题:

两张数据库表关系为一对多,为实现业务逻辑将主表和子表进行了关联,然后使用sum()函数计算主表数据时,发现数据会因为连表重复计算。

1.1具体案例:

订单表和订单商品表是一对多的关系,此时有一个需求是根据商品名称筛选订单。

于是很自然的将订单表和订单商品表做了连表,然后将订单商品表中的商品名称作为筛选字段。

但是查询时还需要根据筛选条件sum()计算订单的总金额,订单金额是主表的数据,此时主表的数据因为连表会重复多次,所以sum()计算了多次订单金额。

2.解决方案

2.1 代码逻辑实现

第一反应是将符合条件的订单id查出来然后再用一条sql去计算金额,但是总感觉两条SQL有点笨,还是尽量想一条SQL实现。

2.2 SQL实现

主要逻辑就是在子查询中给订单id去重后作为筛选条件

复制代码
select  sum(o.order_price) as totalOrderPrice,sum(o.actual_price) as totalActualPrice
from `order` o
left join `user` u
on o.user_id = u.id
where o.id in (
select DISTINCT order_id from `order_goods` where '商品表筛选条件' )
相关推荐
小新同学^O^7 小时前
简单学习 --> Spring事务
数据库·学习·spring
前进的李工7 小时前
MySQL慢查询日志优化实战
数据库·mysql·性能优化
KaMeidebaby8 小时前
卡梅德生物技术快报|禽类成纤维细胞 FISH 实验:鸟类性别染色体基因定位技术实现与数据验证
前端·数据库·其他·百度·新浪微博
ECT-OS-JiuHuaShan8 小时前
彻底定理化:从量子纠缠到量子代谢
数据库·人工智能·学习·算法·生活·量子计算
八月瓜科技8 小时前
用AI来省电?iOS26.5正式版全球推送:信号弱网双提升,AI省电模式上新
数据库·人工智能·科技·深度学习·机器人
dhashdoia8 小时前
GPT-5.5 代码开发实战:Codex与Browser Use深度集成与星链4SAPI优化方案
java·数据库·人工智能·gpt·架构
qq_283720059 小时前
LangChain+FAISS 向量数据库搭建轻量化 RAG 应用
数据库·langchain·faiss
小徐学编程-zZ9 小时前
Test-mall--后端联调与启动
数据库
一写代码就开心9 小时前
redis-cli 客户端查询set集合里面的具体数据
数据库·redis·缓存