我有以下表格分数提供的数据:
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
来源: https://codeday.me/bug/20191118/2028201.html