MySQL分组查询 elt,interval的使用 分数段分布统计

首先介绍一下这两个函数

1.elt()

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

如果N= 1,返回str1,如果N= 2,返回str2,等等。如果N小于1或大于参数个数,返回NULL。ELT()是FIELD()反运算。

mysql> select ELT(1, ‘ej’, ‘Heja’, ‘hej’, ‘foo’);

-> ‘ej’

mysql> select ELT(4, ‘ej’, ‘Heja’, ‘hej’, ‘foo’);

-> ‘foo’

2.interval()

Return the index of the argument that is less than the first argument(小于后面的某个参数,就返回这个参数的前一个位置数字)

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

Returns 0 if N < N1, 1 if N < N2 and so on or -1 if N is NULL. All arguments are treated as integers. It is required that N1 < N2 < N3 < … < Nn for this function to work correctly. This is because a binary search is used (very fast).

mysql> SELECT INTERVAL(23, 1, 15, 17, 30, 44, 200); (23小于30,30的位置是4,于是返回3)

-> 3

mysql> SELECT INTERVAL(10, 1, 10, 100, 1000);

-> 2

mysql> SELECT INTERVAL(22, 23, 30, 44, 200);

-> 0

在项目中的运用,业务场景:根据申报条件个数和申报类型进行去查询每个分组的政策数量

SELECT

elt ( INTERVAL ( condition_count, 0, 3, 5.01, 8.01, 10.1 ), ‘少于3个条件’, ‘少于5个条件’, ‘少于8个条件’, ‘少于10个条件’, ‘多于10个条件’ ) AS difficult,

subsidy_type,

count( 1 ) num

FROM policy_info

GROUP BY difficult, subsidy_type

运行的结果

————————————————
版权声明:本文为CSDN博主「木木_亭」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/dyt443733328/article/details/82900153

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值