导读:本期聚焦于小伙伴创作的《SQL多表连接后如何通过HAVING子句配合聚合函数实现过滤》,敬请观看详情,探索知识的价值。以下视频、文章将为您系统阐述其核心内容与价值。如果您觉得《SQL多表连接后如何通过HAVING子句配合聚合函数实现过滤》有用,将其分享出去将是对创作者最好的鼓励。

在SQL的实际查询工作中,经常会遇到需要先关联多张表获取数据,再对分组后的聚合结果进行筛选的需求,这种场景下WHERE子句无法直接使用聚合函数作为过滤条件,就需要借助HAVING子句配合聚合函数来完成过滤操作。

SQL多表连接后如何通过HAVING子句配合聚合函数实现过滤

多表连接与聚合函数、HAVING子句的基础概念

多表连接是通过JOIN关键字将两张或多张表按照关联字段拼接成一张临时结果集的操作,常见的连接类型有INNER JOIN、LEFT JOIN、RIGHT JOIN等。聚合函数是用于对一组值进行计算并返回单一值的函数,常见的包括COUNT、SUM、AVG、MAX、MIN等。HAVING子句的作用是对GROUP BY分组后的结果集进行筛选,它可以直接使用聚合函数作为过滤条件,这是和WHERE子句最核心的区别。

多表连接后使用HAVING配合聚合函数的典型场景

假设存在两张业务表,一张是用户表user_info,存储用户的基础信息,另一张是订单表order_info,存储用户的订单数据,两张表通过user_id字段关联。现在需要查询出下单次数大于3次的用户信息以及对应的下单总数,这个需求就需要先完成多表连接,再分组聚合,最后用HAVING过滤聚合结果。

表结构说明

user_info表结构如下:

字段名类型说明
user_idint用户ID,主键
user_namevarchar用户姓名
ageint用户年龄

order_info表结构如下:

字段名类型说明
order_idint订单ID,主键
user_idint用户ID,关联user_info表
order_amountdecimal订单金额
create_timedatetime订单创建时间

具体实现SQL示例

首先通过INNER JOIN连接两张表,按照user_id分组统计每个用户的下单次数,再用HAVING筛选下单次数大于3的用户:

-- 查询下单次数大于3次的用户信息及下单总数
SELECT 
    u.user_id,
    u.user_name,
    u.age,
    COUNT(o.order_id) AS order_count,
    SUM(o.order_amount) AS total_amount
FROM 
    user_info u
INNER JOIN 
    order_info o ON u.user_id = o.user_id
GROUP BY 
    u.user_id, u.user_name, u.age
HAVING 
    COUNT(o.order_id) > 3;

上述代码中,INNER JOIN完成了用户表和订单表的关联,GROUP BY按照用户维度分组,COUNT(o.order_id)是统计每个用户的订单数量,HAVING子句中使用COUNT聚合函数作为过滤条件,最终只返回下单次数超过3次的用户数据。

注意事项

  • WHERE子句是在分组前对原始数据进行过滤,HAVING子句是在分组后对聚合结果进行过滤,两者执行顺序不同,不要混淆使用场景。
  • HAVING子句中使用的聚合函数必须和SELECT子句或GROUP BY子句中的聚合逻辑对应,避免出现逻辑错误。
  • 如果多表连接使用LEFT JOIN,那么右表中没有匹配到的记录会显示为NULL,聚合函数统计时会忽略NULL值,需要在HAVING中考虑这种情况的处理。

复杂场景示例

如果需要查询出订单平均金额大于100,且下单次数大于等于2次的用户信息,SQL可以这样写:

-- 查询平均订单金额大于100且下单次数大于等于2次的用户
SELECT 
    u.user_id,
    u.user_name,
    AVG(o.order_amount) AS avg_order_amount,
    COUNT(o.order_id) AS order_count
FROM 
    user_info u
INNER JOIN 
    order_info o ON u.user_id = o.user_id
GROUP BY 
    u.user_id, u.user_name
HAVING 
    AVG(o.order_amount) > 100 
    AND COUNT(o.order_id) >= 2;

这个示例中HAVING子句同时使用了AVG和COUNT两个聚合函数作为过滤条件,实现了更复杂的聚合结果筛选需求。

SQL多表连接HAVING子句聚合函数修改时间:2026-06-20 00:21:13

免责声明:​ 已尽一切努力确保本网站所含信息的准确性。网站内容多为原创整理与精心编撰,观点力求客观中立。本站旨在免费分享,内容仅供个人学习、研究或参考使用。若引用了第三方作品,版权归原作者所有。如内容涉及您的权益,请联系我们处理。
内容垂直聚焦
专注技术核心技术栏目,确保每篇文章深度聚焦于实用技能。从代码技巧到架构设计,为用户提供无干扰的纯技术知识沉淀,精准满足专业提升需求。
知识结构清晰
覆盖从开发到部署的全链路。AI、前端、编程、数据库、服务器、建站、系统层层递进,构建清晰学习路径,帮助用户系统化掌握开发与运维所需的核心技术。
深度技术解析
拒绝泛泛而谈,深入技术细节与实践难点。无论是数据库优化还是服务器配置,均结合真实场景与代码示例进行剖析,致力于提供可直接应用于工作的解决方案。
专业领域覆盖
精准对应开发生命周期。从前端界面到后端编程,从数据库操作到服务器运维,形成完整闭环,一站式满足全栈工程师和运维人员的技术需求。
即学即用高效
内容强调实操性,步骤清晰、代码完整。用户可根据教程直接复现和应用于自身项目,显著缩短从学习到实践的距离,快速解决开发中的具体问题。
持续更新保障
专注既定技术方向进行长期、稳定的内容输出。确保各栏目技术文章持续更新迭代,紧跟主流技术发展趋势,为用户提供经久不衰的学习价值。