找到sql中两个组合列的平均值

ak8*_*k85 7 mysql sql average count

我想找到总共两列的平均值.我想计算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
    )
Run Code Online (Sandbox Code Playgroud)

egg*_*yal 7

根据定义,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).

  • 这是如此接近,这是一个很好的方法,但它是不正确的.两个平均值的总和不是两个总和的平均值.两个平均值除以2的总和是两个总和的平均值.考虑这个伪代码:`avg(1,2,3)+ avg(1,2,3)== 4,但avg(1,2,3,3,2,1)== 2 == avg(avg( 1,2,3),平均(1,2,3))==(平均(1,2,3)+平均(1,2,3))/ 2 (2认同)