9

2つの列の合計の平均を見つけたいです。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 に答える