mysql 区间分组 interval,elt 的运用 【备忘】

感谢分享: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‘);

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

| 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

时间: 2024-07-31 16:58:20

mysql 区间分组 interval,elt 的运用 【备忘】的相关文章

Mysql又一次整理笔记--woods备忘

==============================SQL备忘 CRUD 查询 多表 事件等=============================== -------------------------------------------------------------------------------------------------- 一.数据库 1.创建数据库 create database [if not exists] db_name [character set

Mysql重新整理笔记--woods备忘

==============================SQL备忘 CRUD 查询 多表 事件等=============================== -------------------------------------------------------------------------------------------------- 一.数据库 1.创建数据库 create database [if not exists] db_name [character set

Mysql CPU使用率长期100%的解决思路备忘

最近一台服务器的CPU使用率长期保持在100%的状态,查看进程发现是Mysql服务导致的.于是搜索各方资料,终于成功解决问题.备忘以及分享一下,希望可以帮助各位新手朋友. (服务器运行环境是Windows server2008,Linux思路类似.只是命令行工具不同.) 首先通过cmd 输入 mysql -h localhost -u root -p 回车进入mysql数据库 通过 show processlist; 指令查看当前 mysql 使用频繁的 sql 语句 反复调用此命令发现经常出现

mysql 常用命令(备忘)

1:使用SHOW语句找出在服务器上当前存在什么数据库:mysql> SHOW DATABASES; 2:2.创建一个数据库MYSQLDATAmysql> CREATE DATABASE MYSQLDATA;3:选择你所创建的数据库 mysql> USE MYSQLDATA; (按回车键出现Database changed 时说明操作成功!) 4:查看现在的数据库中存在什么表mysql> SHOW TABLES;5:创建一个数据库表mysql> CREATE TABLE MYT

mysql主从配置&&基于keepalived的主备切换

mysql互为主从设置 && 主备切换配置 需求说明: 1.公司架构一直是一台单独的mysql在线上跑,虽然一直没有出现什么宕机事件,但是出于一个高可用的考虑,提出主从备份.主备切换的需求: 2.实现这个需求的前一段时间只是在做数据库备份的时候实现了主从热备,为了实现主备切换功能,继续操作上述需求: 实验环境: master1:10.1.156.3:3306 master2:10.1.156.5:3306 my.cnf配置文件关于主从这块的修改: master1: server-id =

Mysql 命令备忘

一.mysql中获取字符串长度方法 length: 是计算字段的长度一个汉字是算三个字符,一个数字或字母算一个字符 char_length:不管汉字还是数字或者是字母都算是一个字符 二.mysql字符串长度自动补全 前补:LPAD(字段,4,0) update users set employee_id = LPAD(employee_id,4,0) where id = 1; //第一位的 employee_id少于4位,则前补充0到4位 后补:RPAD(字段,4,0) update user

给MySQL官方提交的bug report备忘

1.  http://bugs.mysql.com/bug.php?id=72215 2.  http://bugs.mysql.com/bug.php?id=72217 3.  http://bugs.mysql.com/bug.php?id=72529 4.  http://bugs.mysql.com/bug.php?id=72646 5.  http://bugs.mysql.com/bug.php?id=72705 6.  http://bugs.mysql.com/bug.php?i

centos6.5上配置apache + mysql + php4.4.9 + eaccelerator-0.9.5 + postgresql-8.3.13 备忘

1.apache + mysql 直接利用 yum 安装 yum -y install httpd httpd-devel mysql mysql-server httpd-manual mod_perl mod_auth_mysql mysql-connector-odbc mysql-devel libdbi-dbd-mysql 2.编译postgresql----- 3.编译php4.4.9./configure --enable-mbstring --with-zlib --withou

centos 6.4 mysql rpm 离线安装【备忘】

离线状态下使用rpm的安装包进行mysql的安装,仅作备忘 准备工作: 官网下载mysql离线rpm安装包(这里就不演示了,拿现成的做演示) 卸载并清理之前mysql安装与卸载的残留 1.检测本机安装的MySQL并卸载 rpm -qa|grep -i mysql 其中那个noarch那个是源地址包,不安装也一样 2.如上图所示,说明系统中已经装有MySQL,将其卸载: [[email protected] ~]# yum remove mysql 然后再次执行第一步查看是否有安装的mysql存在