感谢分享:http://blog.itpub.net/13379967/viewspace-715701/
在统计需求中 有时往往需要对区间进行分组
mysql中可以利用elt函数来实现此类需求
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');
+------