Menu
×
   ❮   
HTML CSS JAVASCRIPT SQL PYTHON JAVA PHP HOW TO W3.CSS C C++ C# BOOTSTRAP REACT MYSQL JQUERY EXCEL XML DJANGO NUMPY PANDAS NODEJS R TYPESCRIPT ANGULAR GIT POSTGRESQL MONGODB ASP AI GO KOTLIN SASS VUE DSA GEN AI SCIPY AWS CYBERSECURITY DATA SCIENCE
     ❯   

PostgreSQL COUNT, AVG, and SUM Functions


COUNT

The COUNT() function returns the number of rows that matches a specified criterion.

If the specified criterion is a column name, the COUNT() function returns the number of columns with that name.

Example

Return the number of customers from the customers table:

postgres=#
postgres=#
SELECT COUNT(customer_id)
FROM customers;
Run Example »

Note: NULL values are not counted.

By specifying a WHERE clause, you can e.g. return the number of customers that comes from London:

Example

Return the number of customers from London:

postgres=#
postgres=#
postgres=#
SELECT COUNT(customer_id)
FROM customers
WHERE city = 'London';
Run Example »

AVG

The AVG() function returns the average value of a numeric column.

Example

Return the averarge price of all the products in the products table:

postgres=#
postgres=#
SELECT AVG(price)
FROM products;
Run Example »

Note: NULL values are ignored.

With 2 Decimals

The above example returned the average price of all products, the result was 28.8663636363636364.

We can use the ::NUMERIC operator to round the average price to a number with 2 decimals:

Example

Return the averarge price of all the products, rounded to 2 decimals:

postgres=#
postgres=#
SELECT AVG(price)::NUMERIC(10,2)
FROM products;
Run Example »

SUM

The SUM() function returns the total sum of a numeric column.

The following SQL statement finds the sum of the quantity fields in the order_details table:

Example

Return the total amount of ordered items:

postgres=#
postgres=#
SELECT SUM(quantity)
FROM order_details;
Run Example »

Note: NULL values are ignored.


×

Contact Sales

If you want to use W3Schools services as an educational institution, team or enterprise, send us an e-mail:
[email protected]

Report Error

If you want to report an error, or if you want to make a suggestion, send us an e-mail:
[email protected]

W3Schools is optimized for learning and training. Examples might be simplified to improve reading and learning. Tutorials, references, and examples are constantly reviewed to avoid errors, but we cannot warrant full correctness of all content. While using W3Schools, you agree to have read and accepted our terms of use, cookie and privacy policy.

Copyright 1999-2025 by Refsnes Data. All Rights Reserved. W3Schools is Powered by W3.CSS.