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

时间:2013-02-09 11:20:18

标签: mysql sql count average

我想找到总共两列的平均值。我想计算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
    )

6 个答案:

答案 0 :(得分:6)

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

答案 1 :(得分:2)

使用avg功能

SELECT avg(col1 + col2)
FROM test
WHERE uid=5;

<强> SQLFIDDLE DEMO

答案 2 :(得分:1)

这是你在找什么?

SELECT avg(col1 + col2)
FROM test
where uid = 5
group by uid

答案 3 :(得分:1)

选择avg(col1 + col2)为avgtotal

FROM测试 在哪里uid = 5

答案 4 :(得分:1)

我在这里得到了答案,所以我会添加这个可能有助于其他人的说明:

1.avg(col1+col2) as avg_col1_plus_col2,
2.avg(col1) + avg(col2) as avg_col1_plus_avg_col2,
3.avg(col1+col2)/2 as avgTotal1, 
4.avg(col1)/2+avg(col1)/2 as avgTotal2

句子1等于句子2,因为eggyal解释,语法可以,但逻辑上它不是我们想要的结果,所以我们需要按照第3和第4句中的列数来划分平均值。

答案 5 :(得分:0)

UIView