登录
首页 >  数据库 >  MySQL

如何使用 MySQL 查询实现分组结果并行展示上半年和下半年统计值?

时间:2024-10-28 08:46:09 153浏览 收藏

小伙伴们有没有觉得学习数据库很有意思?有意思就对了!今天就给大家带来《如何使用 MySQL 查询实现分组结果并行展示上半年和下半年统计值?》,以下内容将会涉及到,若是在学习中对其中部分知识点有疑问,或许看了本文就能帮到你!

如何使用 MySQL 查询实现分组结果并行展示上半年和下半年统计值?

mysql 查询结果分组并行展示

对于分组查询并行展示的问题,可以使用 group by 和 left join 联合实现。

本例中,我们需要根据 name 和 start_date 对查询结果进行分组,并将上半年和下半年的统计 num 求和展示在同一行。

以下 sql 查询可以实现上述需求:

SELECT
    t.name,
    start_date,
    SUM( t.num ) AS shang_sum,
    IFNULL(t2.xia_sum,0)
FROM
    `task` t
    LEFT JOIN ( SELECT NAME, SUM( num ) xia_sum FROM task WHERE MONTH ( start_date ) < 7 GROUP BY `name` ) t2 ON t2.NAME = t.NAME 
WHERE
    MONTH ( start_date ) >= 7 
GROUP BY
    `name`

该查询首先使用 group by 对结果按照 name 进行分组,并计算上半年的 num 求和。然后使用 left join 左连接另一个子查询,该子查询从满足 start_date 在上半年的 task 表中计算下半年的 num 求和。最后,ifnull 函数用于处理下半年的求和结果为 null 的情况,将其替换为 0。

执行该查询后,将输出:

namestart_dateshang_sumxia_sum
ceshi上半年31
sss下半年02

今天带大家了解了的相关知识,希望对你有所帮助;关于数据库的技术知识我们会一点点深入介绍,欢迎大家关注golang学习网公众号,一起学习编程~

相关阅读
更多>
最新阅读
更多>
课程推荐
更多>