mysql按区间group by


在统计需求中 有时往往需要对区间进行分组

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');
+-----------+-----+
| 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)


附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'
        

interval函数格式:        


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
### 回答1: 如果你想按照某个字段的值的区间来分组,可以使用 MySQL 中的 CASE 表达式和 GROUP BY 语句来实现。以下是一个示例: 假设我们有一个表名为 scores,其中包含学生姓名和成绩两列,我们想要按照成绩的区间来分组,并统计每个区间内的学生人数。 首先,我们可以使用 CASE 表达式来将成绩分成不同的区间,例如: ``` SELECT CASE WHEN score >= 90 THEN 'A' WHEN score >= 80 THEN 'B' WHEN score >= 70 THEN 'C' WHEN score >= 60 THEN 'D' ELSE 'F' END AS grade, COUNT(*) AS count FROM scores GROUP BY grade; ``` 这个查询会将成绩分成五个区间,并统计每个区间内的学生人数。 注意,我们在 SELECT 语句中使用了 AS 关键字来为 CASE 表达式创建一个别名,这样我们就可以在 GROUP BY 语句中使用这个别名来分组。 另外,COUNT(*) 函数用于计算每个分组中的行数,也就是每个区间内的学生人数。 ### 回答2: MySQL区间分组可以使用CASE WHEN语句和GROUP BY子句来实现。 假设我们有一个名为"sales"的表,包含了销售数据的信息,其中有一个列"amount"表示销售额。 如果我们希望按照销售额分成三个区间进行分组,可以使用CASE WHEN语句来实现。语法如下: SELECT CASE WHEN amount < 1000 THEN '0-1000' WHEN amount >= 1000 AND amount < 5000 THEN '1000-5000' WHEN amount >= 5000 THEN '5000以上' END AS sales_range, SUM(amount) AS total_amount FROM sales GROUP BY sales_range; 上述查询将会按照销售额区间进行分组,并计算每个区间的总销售额。 例如,如果销售额在0到1000之间,它将被归为'0-1000'区间,如果销售额在1000到5000之间,它将被归为'1000-5000'区间,如果销售额大于等于5000,它将被归为'5000以上'的区间。 最后,我们使用GROUP BY子句将结果按照sales_range进行分组,并计算每个区间的总销售额。 ### 回答3: MySQL区间分组,可以使用CASE WHEN语句和GROUP BY子句来实现。 首先,假设有一个包含学生成绩的表格,其中有学生名字和分数两列。我们想按照分数的区间进行分组并计算每个区间内的学生数量。 可以使用CASE WHEN语句来判断每个分数属于哪个区间,然后使用GROUP BY子句按照区间分组。具体步骤如下: ``` SELECT CASE WHEN score >= 90 THEN '90-100' -- 区间判断条件 WHEN score >= 80 THEN '80-89' WHEN score >= 70 THEN '70-79' WHEN score >= 60 THEN '60-69' ELSE '0-59' END AS score_range, -- 将区间结果设为新列 COUNT(*) AS student_count -- 计算每个区间内的学生数量 FROM scores GROUP BY score_range -- 按区间分组 ``` 在上述示例中,首先使用CASE WHEN语句根据分数的不同判断所属的区间(90-100,80-89,70-79,60-69,0-59),然后将区间结果设为新列score_range。 然后,使用GROUP BY子句按照score_range进行分组。最后,使用COUNT(*)统计每个区间内的学生数量。 这样即可实现按区间分组的功能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值