位置:首頁 > 數據庫 > PostgreSQL教學 > PostgreSQL avg()函數

PostgreSQL avg()函數

PostgreSQL的AVG函數是用來找出各種記錄中的一個字段的平均值。

為了理解AVG函數考慮表COMPANY 有如下記錄:

testdb# select * from COMPANY;
 id | name  | age | address   | salary
----+-------+-----+-----------+--------
  1 | Paul  |  32 | California|  20000
  2 | Allen |  25 | Texas     |  15000
  3 | Teddy |  23 | Norway    |  20000
  4 | Mark  |  25 | Rich-Mond |  65000
  5 | David |  27 | Texas     |  85000
  6 | Kim   |  22 | South-Hall|  45000
  7 | James |  24 | Houston   |  10000
(7 rows)

現在,假設基於上述表要計算平均的工資,那麼可以通過使用下麵的命令:

testdb=# SELECT AVG(SALARY) FROM COMPANY;

以上PostgreSQL的表會產生以下結果:

        avg
 ------------------
  37142.8571428571
(1 row)

可以把平均使用GROUP BY子句集合各種記錄。下麵的例子將平均到一個人的所有相關的記錄,將計算出每個人的平均工資。

testdb=# SELECT name, AVG(SALARY) FROM COMPANY GROUP BY name;
  name  |  avg
 -------+-------
  Teddy | 20000
  Paul  | 20000
  Mark  | 65000
  David | 85000
  Allen | 15000
  Kim   | 45000
  James | 10000
(7 rows)