首页 / MYSQL / mysql-不涉及数据的多列平均值
mysql-不涉及数据的多列平均值
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了mysql-不涉及数据的多列平均值,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1120字,纯文字阅读大概需要2分钟。
内容图文
![mysql-不涉及数据的多列平均值](/upload/InfoBanner/zyjiaocheng/883/035ebe8095c844898366b4f2b053db9f.jpg)
我有以下表格分数提供的数据:
No ! id ! A ! B ! average !
------------------------------------------
1 ! 01 ! 80 ! 60 ! 70 !
2 ! 02 ! ! 60 ! 30 !
3 ! 03 ! 0 ! 60 ! 30 !
4 ! 04 ! 80 ! ! 40 !
我想使用以下代码获取列A和列B的平均值:
Select id, (avg(A)+avg(B))/2 as Average
from score
Group by id;
问题是ID 02和ID 04只有一个数据.平均值会将其计为0,而不是没有数据.
我想要的桌子是这样的
我有以下表格分数提供的数据:
No ! id ! A ! B ! average !
------------------------------------------
1 ! 01 ! 80 ! 60 ! 70 !
2 ! 02 ! ! 60 ! 60 !
3 ! 03 ! 0 ! 60 ! 30 !
4 ! 04 ! 80 ! ! 80 !
有人可以帮助我吗?
解决方法:
试试这个查询:
SELECT id, (SUM(COALESCE(A,0)) + SUM(COALESCE(B,0))) / (COUNT(A) + COUNT(B))
FROM score
GROUP by id
这里的技巧是通过将SUM除以COUNT并适当地使用COALESCE()来处理NULL值,从而计算平均值.请记住,默认情况下,MySQL聚合函数(SUM,COUNT等)会忽略NULL值.
我测试了该查询,您可以在A和B之外添加其他列,但它似乎仍在工作.
演示:
SQLFiddle
内容总结
以上是互联网集市为您收集整理的mysql-不涉及数据的多列平均值全部内容,希望文章能够帮你解决mysql-不涉及数据的多列平均值所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。