mysql按区间分组获取各数量
2015-10-15 00:00
525 查看
对区间进行分组并且统计落在各区间内的数据量
主要使用 etl 和 INTERVAL 函数实现
现在要进行统计,小于100的,100~500的,500~1000的,1000以上的,这各个区间的id数
利用interval划出4个区间
再利用elt函数将4个区间分别返回一个列名
如果需要按从小到大排序的话 可以在列名定义时稍加一个首字符 对各档区间进行排序
主要使用 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)
相关文章推荐
- MySQL中的integer 数据类型
- MySQL存储过程
- mysql中int、bigint、smallint 和 tinyint的区别与长度
- mysql load data 导出、导入 csv
- source命令执行SQL脚本文件
- MySQL创建用户及权限控制
- MySQL管理数据表
- linux下mysql添加用户
- mysql procedure
- mysql触发器
- MySQL 备份和恢复策略
- mac下安装mysql(转载)
- mysql 修改编码 Linux/Mac/Unix/通用(杜绝修改后无法启动的情况!)
- MySQL数据的导出、导入(mysql内部命令:mysqldump、mysql)
- mysql数据行转列
- Linux下修改MySQL编码的方法
- MySQL Server 日志
- MySQL 安全事宜
- MySQL 备份与恢复