我想找到总共两列的平均值.我想计算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).
此外,加法的可交换性给出了我们(SUM(col1)SUM(col2))/ COUNT(*)= SUM(col1 col2)/ COUNT(*),因此AVG(col1 col2).