PostgreSQL的SUM函数用来找出各种记录中的一个字段的总和。
为了理解SUM函数考虑表COMPANY 有如下记录: www.gitbook.net
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)
www.gitbook.net
现在,假设根据上表要计算所有的工资总额,那么可以通过使用下面的命令: gitbook.net
testdb# SELECT SUM(salary) FROM company; gitbook.net
以上PostgreSQL的表会产生以下结果: gitbook.net
sum
--------
260000
(1 row)
www.gitbook.net
可以使用GROUP BY子句设为各种记录的总和。下面的例子将统计一个人的所有相关的记录,将计算出有每个人的工资。
gitbook.net
testdb# SELECT name, SUM(salary) FROM company GROUP BY name; gitbook.net
以上PostgreSQL的表会产生以下结果: www.gitbook.net
name | sum -------+------- Teddy | 20000 Paul | 20000 Mark | 65000 David | 85000 Allen | 15000 Kim | 45000 James | 10000 (7 rows) gitbook.net