mysql分组取数量_mysql按区间分组获取各数量

对区间进行分组并且统计落在各区间内的数据量

主要使用 etl 和 INTERVAL 函数实现

mysql> select * from k1;

+------+------+

| id   | yb   |

+------+------+

|    1 |  100 |

|    2 |   11 |

|    3 |    5 |

|    4 |  501 |

|    5 | 1501 |

|    6 |    1 |

+------+------+

现在要进行统计,小于100的,100~500的,500~1000的,1000以上的,这各个区间的id数

利用interval划出4个区间

再利用elt函数将4个区间分别返回一个列名

mysql> select elt(interval(d.yb,0, 100, 500, 1000), ‘less100‘, ‘100to500‘, ‘500to1000‘, ‘more1000‘) as yb_level, count(d.id) as cnt

-> from k1 d

-> group by elt(interval(d.yb, 0, 100, 500, 1000), ‘less100‘, ‘100to500‘, ‘500to1000‘, ‘more1000K‘);

+-----------+-----+

| yb_level  | cnt |

+-----------+-----+

| 100to500  |   1 |

| 500to1000 |   1 |

| less100   |   3 |

| more1000  |   1 |

+-----------+-----+

4 rows in set (0.00 sec)

如果需要按从小到大排序的话 可以在列名定义时稍加一个首字符 对各档区间进行排序

mysql> select elt(interval(d.yb,0, 100, 500, 1000), ‘1/less100‘, ‘2/100to500‘, ‘3/500to1000‘, ‘4/more1000‘) as yb_level, count(d.id) as cnt

-> from k1 d

-> group by elt(interval(d.yb, 0, 100, 500, 1000), ‘1/less100‘, ‘2/100to500‘, ‘3/500to1000‘, ‘4/more1000K‘);

+-------------+-----+

| yb_level    | cnt |

+-------------+-----+

| 1/less100   |   3 |

| 2/100to500  |   1 |

| 3/500to1000 |   1 |

| 4/more1000  |   1 |

+-------------+-----+

4 rows in set (0.00 sec)

原文:http://my.oschina.net/u/914655/blog/517693

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值