9

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

6 回答 6

11

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

于 2013-02-09T11:27:01.253 回答
2

要使用 avg 函数,

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

SQLFIDDLE 演示

于 2013-02-09T11:28:42.410 回答
1
SELECT avg(col1 + col2) as avgtotal

FROM test
WHERE uid=5
于 2013-02-09T11:42:36.840 回答
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

正如 egyal 解释的那样,句子 1 等于句子 2,语法还可以,但从逻辑上讲它不是我们想要的结果,因此我们需要将平均值除以列数,如句子 3 和 4 中所示。

于 2014-11-11T11:10:24.933 回答
0

这是你想要的?

SELECT avg(col1 + col2)
FROM test
where uid = 5
group by uid
于 2013-02-09T11:29:34.373 回答
0
SELECT ((SUM(col1) + SUM(col2)) / (COUNT(col1) + COUNT(col2))) as a
FROM test
WHERE uid=5;
于 2019-01-17T11:21:12.107 回答