我有一个非常简单的表:
CREATE TABLE IF NOT EXISTS LuxLog (
Sensor TINYINT,
Lux INT,
PRIMARY KEY(Sensor)
)
它包含来自不同传感器的数千个日志.
我希望所有传感器都有Q1和Q3.
我可以对每个数据进行一次查询,但对我来说最好对所有传感器进行一次查询(从一个查询中获取Q1和Q3)
我虽然这是一个相当简单的操作,因为四分位数被广泛使用并且是频率计算中的主要统计变量之一.事实是,我发现了大量过于复杂的解决方案,而我希望找到一些简洁明了的东西.
任何人都可以给我一个提示?
编辑:这是我在网上找到的一段代码,但它对我不起作用:
SELECT SUBSTRING_INDEX(
SUBSTRING_INDEX(
GROUP_CONCAT( -- 1) make a sorted list of values
Lux
ORDER BY Lux
SEPARATOR ','
)
, ',' -- 2) cut at the comma
, 75/100 * COUNT(*) -- at the position beyond the 90% portion
)
, ',' -- 3) cut at the comma
, -1 -- right after the desired list entry
) AS `75th Percentile`
FROM LuxLog
WHERE Sensor=12
AND Lux<>0<