mysql – 同一查询中count()的平均值
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了mysql – 同一查询中count()的平均值,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1288字,纯文字阅读大概需要2分钟。
内容图文
![mysql – 同一查询中count()的平均值](/upload/InfoBanner/zyjiaocheng/889/8eca4e33921c471abc7bbdb823341774.jpg)
我正在进行一项任务,要求我找到每个模块的资源数量的平均值.当前表格如下所示:
ResourceID ModulID
1 1
2 7
3 2
4 4
5 1
6 1
所以基本上,我试图弄清楚如何获得平均资源数量.唯一的
这里的相关测试数据是模块1,它有3个不同的资源连接到它.但我需要显示所有结果.
这是我的代码:
select avg(a.ress) GjSnitt, modulID
from
(select count(ressursID) as ress
from ressursertiloppgave
group by modulID) as a, ressursertiloppgave r
group by modulID;
显然它不起作用,但我目前正处于失去改变的地步.我真的很感激你们的任何投入.
解决方法:
这是您正在执行的查询,用稍微不那么钝的语法编写.
SELECT
avg(a.ress) as GjSnitt
, modulID
FROM
(SELECT COUNT(ressursID) as ress
FROM ressursertiloppgave
GROUP BY modulID) as a
CROSS JOIN ressursertiloppgave r <--- Cross join are very very rare!
GROUP BY modulID;
你正在交叉加入表格,共计(6×6 =)36行并将其缩减为4,但由于总计数为36,结果是错误的.
这就是你永远不应该使用隐式连接的原因.
将查询重写为:
SELECT AVG(a.rcount) FROM
(select count(*) as rcount
FROM ressursertiloppgave r
GROUP BY r.ModulID) a
如果你想要个人行数和底部的平均值:
SELECT r1.ModulID, count(*) as rcount
FROM ressursertiloppgave r1
GROUP BY r1.ModulID
UNION ALL
SELECT 'avg = ', AVG(a.rcount) FROM
(select count(*) as rcount
FROM ressursertiloppgave r2
GROUP BY r2.ModulID) a
内容总结
以上是互联网集市为您收集整理的mysql – 同一查询中count()的平均值全部内容,希望文章能够帮你解决mysql – 同一查询中count()的平均值所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。