本文摘自PHP中文网,作者藏色散人,侵删。
要得到一组数据的中位数(例如某个地区或某家公司的收入中位数),我们一般要将这一任务细分为 3 个小任务:1.将数据排序,并给每一行数据给出其在所有数据中的排名;
2.找出中位数的排名数字;
3.找出中间排名对应的值;
下面以某公司员工月收入为例,示例 MySQL 的一些复杂语句的使用。
方法一
创建测试表
首先创建一个收入表,建表语句为:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 | CREATE TABLE IF NOT EXISTS `employee` (
`id` INT AUTO_INCREMENT PRIMARY KEY,
`name` VARCHAR(10) NOT NULL DEFAULT '' ,
`income` INT NOT NULL DEFAULT '0'
)
ENGINE = InnoDB
DEFAULT CHARSET = utf8;
INSERT INTO `employee` (`name`, `income`)
VALUES ( '麻子' , 20000);
INSERT INTO `employee` (`name`, `income`)
VALUES ( '李四' , 12000);
INSERT INTO `employee` (`name`, `income`)
VALUES ( '张三' , 10000);
INSERT INTO `employee` (`name`, `income`)
VALUES ( '王二' , 16000);
INSERT INTO `employee` (`name`, `income`)
VALUES ( '土豪' , 40000);
|
完成任务 1
将数据排序,并给每一行数据给出其在所有数据中的排名:
1 2 3 4 5 6 7 | SELECT t1.name, t1.income, COUNT (*) AS rank
FROM employee AS t1,
employee AS t2
WHERE t1.income < t2.income
OR (t1.income = t2.income AND t1.name <= t2.name)
GROUP BY t1.name, t1.income
ORDER BY rank;
|
查询结果为:

完成小任务 2
找出中位数的排名数字:
1 2 | SELECT ( COUNT (*) + 1) DIV 2 as rank
FROM employee;
|
查询结果为:

完成小任务 3
1 2 3 4 5 6 7 8 9 | SELECT income AS median
FROM (SELECT t1.name, t1.income, COUNT (*) AS rank
FROM employee AS t1,
employee AS t2
WHERE t1.income < t2.income
OR (t1.income = t2.income AND t1.name <= t2.name)
GROUP BY t1.name, t1.income
ORDER BY rank) t3
WHERE rank = (SELECT ( COUNT (*) + 1) DIV 2 FROM employee)
|
查询结果为:
阅读剩余部分
相关阅读 >>
c语言必须学mysql吗?
mysql数据库准备工作实例分享
mysql怎么修改列名为主键?
mysql的安装与配置经验分享
mysql 备份与迁移 数据同步方法
linux下如何安装mysql
mysql数据库导出数据字典文档word或者html的3个工具介绍
正版数据库管理工具 navicat for mysql 中文版软件安装、破解步骤
mysql优化的几种方法
mysql语句与java代码实现按需过滤企业员工的资质证书
更多相关阅读请进入《mysql》频道 >>
机械工业出版社
本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。
转载请注明出处:木庄网络博客 » 在 MySQL 中,如何计算一组数据的中位数