计算多个表列的平均值
在数据库表操作中,经常需要计算多个列的平均值。当我们需要总结或分析数据时,这变得特别有用。让我们考虑一个具体的示例来演示该过程。
场景:
我们有一个名为“Request”的表,其中的列表示值 R1、R2、R3、R4,和R5。我们想要确定表中每条记录的这些值的平均值。
初始方法:
为了实现此目的,您最初尝试了以下查询:
Select Req_ID, Avg(R1+R2+R3+R4+R5) as Average from Request Group by Req_ID
但是,此查询未提供预期结果。它计算值的总和,而不是平均值。
原因:
使用 AVG 聚合函数时,确保提供的参数是表达式非常重要其计算结果为单个数值。在本例中,您将多列的值相加,从而得到总和。
解决方案:
您可以使用两种方法来计算平均值正确:
1.使用子查询(2008 语法):
SELECT *, (SELECT AVG(c) FROM (VALUES(R1), (R2), (R3), (R4), (R5)) T (c)) AS [Average] FROM Request
在此方法中,子查询用于计算平均值。子查询从每列中选择值并将它们视为单独的行。然后,应用 AVG 聚合函数来计算平均值。
2.在子查询中使用 UNION(2005 语法):
SELECT *, (SELECT AVG(c) FROM (SELECT R1 UNION ALL SELECT R2 UNION ALL SELECT R3 UNION ALL SELECT R4 UNION ALL SELECT R5) T (c)) AS [Average] FROM Request
此方法使用 UNION 将不同列中的所有值组合到单个列中。然后将 AVG 聚合函数应用于组合列以计算平均值。
结果:
两种方法都会为请求中的每条记录提供正确的平均值桌子。通过遵循这些解决方案中的任何一个,您都可以准确计算多个表列的平均值并获得所需的结果。
以上是如何计算数据库表中多列的平均值?的详细内容。更多信息请关注PHP中文网其他相关文章!