最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

在MySQL中,如何计算一组数据的中位数

来源:懂视网 责编:小采 时间:2020-11-09 06:57:09
文档

在MySQL中,如何计算一组数据的中位数

在MySQL中,如何计算一组数据的中位数:要得到一组数据的中位数(例如某个地区或某家公司的收入中位数),我们一般要将这一任务细分为 3 个小任务:1.将数据排序,并给每一行数据给出其在所有数据中的排名;2.找出中位数的排名数字;3.找出中间排名对应的值;下面以某公司员工月收入为例,示例 M
推荐度:
导读在MySQL中,如何计算一组数据的中位数:要得到一组数据的中位数(例如某个地区或某家公司的收入中位数),我们一般要将这一任务细分为 3 个小任务:1.将数据排序,并给每一行数据给出其在所有数据中的排名;2.找出中位数的排名数字;3.找出中间排名对应的值;下面以某公司员工月收入为例,示例 M
要得到一组数据的中位数(例如某个地区或某家公司的收入中位数),我们一般要将这一任务细分为 3 个小任务:

1.将数据排序,并给每一行数据给出其在所有数据中的排名;

2.找出中位数的排名数字;

3.找出中间排名对应的值;

下面以某公司员工月收入为例,示例 MySQL 的一些复杂语句的使用。

方法一

创建测试表

首先创建一个收入表,建表语句为:

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

将数据排序,并给每一行数据给出其在所有数据中的排名:

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;

查询结果为:

492a81f0598eb5622f488d41ac30bdf.png

完成小任务 2

找出中位数的排名数字:

SELECT (COUNT(*) + 1) DIV 2 as rank
FROM employee;

查询结果为:

210205328ff0784952f3dfa5b67f612.png

完成小任务 3

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)

查询结果为:

835e75d07d4ffd52a5482c8a08e89f3.png

至此,我们就找到了如何从一组数据中获得中位数的方法。

方法二

下面,来介绍另外一种优化排名语句的方法。

我们都知道如何给一组数据做排序操作,在本例中,实现方法如下:

SELECT name, income
FROM employee
ORDER BY income DESC

查询结果为:

f5b6fd78598104e12fb46a8db24c6ed.png

那我们可不可以更进一步,对查询出的结果加一列,这一列的数据为排名呢?

我们可以通过 3 个自定义变量的方法来实现这一目标:

第一个变量用来记录当前行数据的收入

第二个变量用来记录上一行数据的收入

第三个变量用来记录当前行数据的排名

SET @curr_income := 0;
SET @prev_income := 0;
SET @rank := 0;
SELECT `name`,
 @curr_income := income AS income,
 @rank := if(@prev_income != @curr_income, @rank + 1, @rank) AS rank,
 @prev_income := @curr_income AS dummy
FROM employee
ORDER BY income DESC

查询结果如下:

e755927d76f35a4d443d9fed3c4b927.png

然后再找出中位数的排名数字,进一步找出收入的中位数:

SET @curr_income := 0;
SET @prev_income := 0;
SET @rank := 0;
SELECT income AS median
FROM (SELECT `name`,
 @curr_income := income AS income,
 @rank := if(@prev_income != @curr_income, @rank + 1, @rank) AS rank,
 @prev_income := @curr_income AS dummy
 FROM employee
 ORDER BY income DESC) AS t1
WHERE t1.rank = (SELECT (COUNT(*) + 1) DIV 2 FROM employee)

查询结果为:

203ebad79cbd1463414c89cf3b5b959.png

至此,我们找了两种方法来解决中位数的问题。撒花。

推荐:《mysql教程》

文档

在MySQL中,如何计算一组数据的中位数

在MySQL中,如何计算一组数据的中位数:要得到一组数据的中位数(例如某个地区或某家公司的收入中位数),我们一般要将这一任务细分为 3 个小任务:1.将数据排序,并给每一行数据给出其在所有数据中的排名;2.找出中位数的排名数字;3.找出中间排名对应的值;下面以某公司员工月收入为例,示例 M
推荐度:
标签: 数据 如何 中位数
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top