- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
例如,假设我有一个表,其中包含人名列表以及他们来自的国家/地区的 ID。如果我要制作一个饼图来显示每个国家有多少人,并且我展示了所有这些人,那么饼图上的部分太多了,以至于几乎无法区分线条。
假设查询看起来像这样:
SELECT COUNT(name) AS n, countryId
FROM persons
GROUP BY countryId
ORDER BY n DESC
如果我通过在末尾添加 LIMIT 20
将此查询中的结果数限制为前 20 个,那将使整个饼图更具可读性,因为它只会显示 20师。但是它的视觉表示是不正确的。整个饼图将不再代表所有人,它只代表前 20 个国家。
因此,如果我希望饼图的整个圆圈实际上代表数据库中的所有人,我想要的是饼图的第 21 部分相当于,比方说 14%,并且将包含属于不在前 20 名中的任何国家/地区的所有人员。
我的问题是,这可以在单个查询中完成吗?如果是这样,怎么办?
我知道我可以在这里做另一个查询,计算来自不在前 20 名中的国家/地区的结果数量,但如果可能的话,我试图避免对该解决方案进行两次查询。
SELECT COUNT(name) AS n
FROM persons
WHERE countryId NOT IN ( {$concatenatedIdsFromPreviousQuery} )
最佳答案
我会使用您的第一个查询并在应用程序代码中决定要单独显示多少个国家,以及将多少个国家显示到“其他”组中。例如,如果结果集中的前三个国家/地区包含 95% 的用户群,则该图表将包含 17 个国家/地区,其饼图切片将无法区分,因为它们的百分比低于 1%。
您可以对单独显示的国家/地区数量或它们的百分比设置阈值,但无论哪种方式,您从数据库中获得的实际值在某些情况下都会使图表看起来很糟糕。
这个答案是作为概念证明提供的。我不建议在生产代码中使用它,原因有两个:
让我们分两步构建查询。首先,让我们编写一个查询,以绝对值和百分比的形式生成图表中显示的数字:
SELECT countryId, COUNT(*) AS cnt,
COUNT(*)*100/(SELECT COUNT(*) FROM persons) AS percent
FROM persons
GROUP BY countryId
ORDER BY cnt DESC
此查询计算每个国家/地区的人数,并计算该值与表中总人数的比率,以百分比表示。
一些说明:
内部查询 SELECT COUNT(*) FROM persons
计算表中的人数。需要计算百分比。它可以在单独的查询中提取,并将其值存储在变量中:
SELECT COUNT(*) INTO @total FROM persons;
SELECT countryId, COUNT(*) AS cnt,
COUNT(*)*100/@total AS percent
FROM persons
GROUP BY countryId
ORDER BY cnt DESC
但它不会缩短执行时间。 MySQL 足够聪明,只运行一次内部查询并将结果用于外部查询(它自己在内部执行变量技巧,因为内部查询不依赖于外部查询,它总是返回相同的值)。
因为它乘以 100
,所以以 percent
计算的值是要在图表中显示的最终值。对于通常的处理,最好将比率计算为 COUNT(*)/@total
,并且仅当该值显示在 UI 中时才将该值乘以 100
。
我们现在可以处理上述查询生成的结果集,将列表底部的国家聚合到一个组中:
SELECT IF(percent < 5, -1, countryId) AS groupId,
IF(percent < 5, 1, 0) AS isGroup,
SUM(cnt) AS cnt, SUM(percent) AS percent
FROM (
SELECT countryId, COUNT(*) AS cnt,
COUNT(*)*100/(SELECT COUNT(*) FROM persons) AS percent
FROM persons
GROUP BY countryId
) t
GROUP BY groupId
ORDER BY isGroup ASC, percent DESC
查询使用 5%
的阈值来决定国家是单独显示还是添加到“其他国家/地区”组中。
groupId
是 -1
对于“其他国家”组或图表中显示的国家的 countryId
。
isGroup
(1
或 0
)用于获取列表末尾的组,在独立国家(ORDER BY isGroup ASC
).然后,独立国家列表按 percent DESC
排序。 SELECT
列表中不需要isGroup
,可以直接将其定义替换到ORDER BY
子句中。
如果您在源代码中有国家列表,那么这就是您的查询。但是,如果您在数据库的表中有列表,那么您可能也需要获取他们的名字。加入countries
表,查询变为:
SELECT IF(percent < 5, '-- other countries --', c.countryName) AS groupId,
SUM(cnt) AS cnt, SUM(t.percent) AS percent
FROM (
SELECT p.countryId, COUNT(*) AS cnt,
COUNT(*)*100/(SELECT COUNT(*) FROM persons) AS percent
FROM persons p
GROUP BY countryId
) t
LEFT JOIN countries c ON t.countryId = c.countryId
GROUP BY groupId
ORDER BY IF(t.percent < 5, 1, 0) ASC, percent DESC
加入countries
表不会显着增加执行时间。世界上大约有 200 个国家,countries
表非常小。
关于mysql - "Other results"饼图数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30024099/
我有点困惑为什么在 RoutineRetrieved 函数中分配 ACTIVITYIMAGE 时使用 result.getInt(2) 并在分配 SLOT 时使用 result.getInt(3)..
我是android领域的新手,我想从响应json数组访问每个结果元素,但我无法做到这一点,我试图获取每个元素,但我只得到一个值“rohit1”是第一个元素。请帮助我。 我是 rohit parmar,
我只有从 sql 查询返回的一行 (count(*)),但在执行包时,它向我显示上述错误,并且包失败。 我将结果类型设置为“单行”,并将查询的输出(select count(*) as 'result
我正在尝试使用Diesel将简单的原始SQL转换为MySQL,如本示例所示: https://docs.diesel.rs/diesel/fn.sql_query.html let users = s
我正在尝试 Play 框架的第一个示例,但出现了此错误 在我的路线文件中: # API # ~~~~ GET /api/geotweets/index controllers.api.GeoTw
这段代码可以返回null吗? (this.Result == Result.OK) 此行(或类似行)是否可以返回除 true 或 false 之外的任何内容(例如 null)? 最佳答案 (this.
我有一个 SSIS 执行 SQL 任务。它返回一个完整的结果集(即一个表)。但是,当我执行包时出现以下错误。我已经正确地为返回的结果集命名。 [执行 SQL 任务] 错误:对于完整的结果集和 XML
最近我刚刚将 swift 2.3 项目转换为 3.2,alamofire 也得到了转换,我收到了很多问题,其中大部分都已解决,现在我被给定的两个问题所困扰 问题在 alamofire 的 Respon
我在 R 中收到以下错误消息: Error in .verify.JDBC.result(r, "Unable to retrieve JDBC result set", : Unable to r
关闭。这个问题是not reproducible or was caused by typos .它目前不接受答案。 想改善这个问题吗?更新问题,使其成为 on-topic对于堆栈溢出。 去年关闭。
我正在使用一个简单的命令运行以下存储过程sp_MSforeachdb。我的问题是如何限制结果仅显示至少有 1 条记录满足命令的数据库: 这是我的存储过程: EXECUTE master.sys.sp_
我在单独的线程中运行一些代码: fn f1() -> Result { Err("err1".to_string()) } fn f2() -> Result { Err("err2"
我在这里尝试使用 AsyncTask 从 OWM API 显示 7 天的天气预报。 doInBackground(String...param) 方法也工作正常。我检查了 LOGCAT。 异步完成执行
我已经创建了mysql的索引和全文索引,后端存储引擎是MyISAM。 mysql> show index from play_movie; +------------+------------+---
我有一个表articles,它的结构如下: id, name, date, contents 我有一个表authors,它的结构如下: id, article_id, name, email 一篇文章
我很困惑我们是否应该创建单独的 API 来获取结果和结果计数,或者我们应该只根据结果 API 中的查询字符串来获取计数。 /api/results/ : Fetches all records /ap
我正在制作一个将两个数字相除的系统,如果第二个数字不存在,它将选择第一个数字。这是代码: let new_num: f32 = match num1/num2 { Ok(num) => n
这个问题在这里已经有了答案: Why am I getting "unused Result which must be used ... Result may be an Err variant,
我正在修改 the texture synth 中的示例之一项目: use texture_synthesis as ts; fn main() -> Result { //create a
这个问题已经有答案了: 已关闭11 年前。 Possible Duplicate: ^ operator in java 我假设 c ^ d是一个类似“的幂”的计算,所以c = 5 , d = 2 ,
我是一名优秀的程序员,十分优秀!