iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >【工作记录】mysql中实现分组统计的三种方式
  • 485
分享到

【工作记录】mysql中实现分组统计的三种方式

mysql 2023-08-30 13:08:02 485人浏览 八月长安
摘要

前言 实际工作中对范围分组统计的需求还是相对普遍的,本文记录下在Mysql中通过函数和sql完成分组统计的实现过程。 数据及期望 比如我们获取到了豆瓣电影top250,现在想知道各个分数段的电影总数. 表数据如下: 期望结果: 实现方案

前言

实际工作中对范围分组统计的需求还是相对普遍的,本文记录下在Mysql中通过函数和sql完成分组统计的实现过程。

数据及期望

比如我们获取到了豆瓣电影top250,现在想知道各个分数段的电影总数.

表数据如下:

表数据结构
期望结果:
期望结果

实现方案

主要思路是根据score的范围设置别名,然后按照别名统计即可。

方案一:

select tmp.level, count(1) as cnt from    (select        score,        case            when score >= 7 and score < 8 then '[7,8)'            when score >= 8 and score < 8.5 then '[8,8.5)'            when score >= 8.5 and score < 9 then '[8.5,9)'            when score >= 9 and score < 9.5 then '[9,9.5)'            when score >= 9.5 and score < 10 then '[9.5,10)'        end as level    from `douban_movie_top250` limit 20 ) tmpgroup by tmp.levelorder by tmp.level asc

方案二:

select    case tmp.level        when 1 then '[7,8)'        when 2 then '[8,8.5)'        when 3 then '[8.5,9)'        when 4 then '[9,9.5)'        when 5 then '[9.5,10)'    end as level, count(1) as cntfrom(select score, interval(score, 7, 8, 8.5, 9, 9.5) as level from `douban_movie_top250` limit 20) tmpgroup by tmp.levelorder by tmp.level asc

INTERVAL()函数介绍

INTERVAL()函数可以返回分段后的结果,语法如下:

​ INTERVAL(N,N1,N2,N3,…)

其中,N是要判断的数值,N1,N2,N3,…是分段的间隔。

sql中用到了interval函数,interval(score, 7, 8, 8.5, 9, 9.5)返回的是score所处阶段的索引,比如返回1代表score在[7,8)范围内,前闭后开,依次类推。

分数段对应值
[7,8)1
[8,8.5)2
[8.5,9)3
[9,9.5)4
[9.5,10)5

我们直接查询下这个函数使用的结果验证下:

select score, interval(score, 7, 8, 8.5, 9, 9.5) as level from `douban_movie_top250` limit 20

结果如下:
interval验证
可以看到验证结果是正确的,依据这个特性还是可以做不少事情的。

方案三:

select level, count(1) as cnt from (select score, elt(interval(score, 7, 8, 8.5, 9, 9.5), '[7,8)','[8,8.5)', '[8.5,9)', '[9,9.5)','[9.5,10)') as levelfrom `douban_movie_top250` limit 20) tmpgroup by tmp.level order by tmp.level asc;

这个sql中用到了elt函数和interval函数,大致可以猜测到elt函数做的事情就是上面方案二中case…when…做的事情。

ELT函数简介

​ ELT()函数是分值函数,功能有点类似很多编程语言中的switch关键字。

语法:

​ ELT(N,str1,str2,str3,…)

其中N是要判断的数值,如果N=1,则返回str1,如果N=2,则返回str2,以此类推。

总结

本文针对分组统计提出了三种实现方式,各有优劣吧。

针对以上内容有任何疑问或者建议欢迎留言评论~

创作不易,欢迎一键三连~~~

来源地址:https://blog.csdn.net/u010361276/article/details/132207726

您可能感兴趣的文档:

--结束END--

本文标题: 【工作记录】mysql中实现分组统计的三种方式

本文链接: https://www.lsjlt.com/news/382909.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作