我想查找两列总计的平均值。我想计算col1和col2的总数,然后找到平均值(它们在多少个不同的行中)。
我设法在这个sqlfiddle中提出了一个解决方案(另请参见下文),这是最好的方法吗?我最初以为我需要使用avg函数,但无法使用它来解决。
CREATE TABLE test ( id INT NOT NULL AUTO_INCREMENT PRIMARY KEY, uid INT, col1 INT, col2 INT ) DEFAULT CHARACTER SET utf8 ENGINE=InnoDB; INSERT INTO test (id, uid, col1, col2) VALUES (1,5,8,12), (2,1,2,3), (3,1,2,33), (4,5,25,50), (5,5,22,3); ( SELECT ((sum(col1) + sum(col2))/count(*)) FROM test WHERE uid=5 )
根据定义,AVG(col1) = SUM(col1)/COUNT(*)并且AVG(col2) = SUM(col2)/COUNT(*),因此(SUM(col1)+SUM(col2))/COUNT(*)= AVG(col1) + AVG(col2)。
AVG(col1) = SUM(col1)/COUNT(*)
AVG(col2) = SUM(col2)/COUNT(*)
(SUM(col1)+SUM(col2))/COUNT(*)
AVG(col1) + AVG(col2)
同样,加法的可交换性给了我们(SUM(col1)+SUM(col2))/COUNT(*) = SUM(col1+col2)/COUNT(*),因此AVG(col1+col2)。
(SUM(col1)+SUM(col2))/COUNT(*) = SUM(col1+col2)/COUNT(*)
AVG(col1+col2)