Preamble
PostgreSQL MAX function returns the maximum value of the expression.
Syntax of the max function in PostgreSQL
SELECT max(aggregate_expression_id)
FROM tabs
[WHERE conds];
Or the syntax of the max function when grouping results into one or more columns:
SELECT expression1_id,2_id,..._n_id,
max(aggregate_expression_id)
FROM tabs
[WHERE conds]
GROUP BY expression1_id,2_id,..._n_id;
Parameters and arguments of the function
- expression1_id, expression2_id,… expression_n_id – Expressions that are not enclosed in the max function and must be included in the GROUP BY operator at the end of the SQL query.
- aggregate_expression_id – This is the column or expression from which the maximum value will be returned.
- tabs – These are the tables from which you want to get the records. At least one table must be specified in the FROM operator.
- WHERE conditions – Optional. These are the conditions that must be met to select records.
The max function can be used in the following PostgreSQL versions
PostgreSQL 11, PostgreSQL 10, PostgreSQL 9.6, PostgreSQL 9.5, PostgreSQL 9.4, PostgreSQL 9.3, PostgreSQL 9.2, PostgreSQL 9.1, PostgreSQL 9.0, PostgreSQL 8.4.
Single Expression Example
Let’s look at some examples of max functions to understand how to use max in PostgreSQL.
For example, you might want to select all entries with a maximum quantity from an inventory table as max(quantity) AS “Highest Quantity”.
SELECT max(quantity) AS "Highest Quantity"
FROM inventory;
In this example of the max function, we added the expression max(quantity) AS “Highest Quantity”. As a result, “Highest Quantity” will be displayed as the field name when the result set is returned.
Example using GROUP BY
In some cases, you will need to use the GROUP BY operator with the max function.
For example, you can also use the max function to return a department and the maximum quantity from the inventory table.
SELECT depart, max(quantity) AS "Highest Quantity"
FROM inventory
GROUP BY depart;
Since your SELECT operator has one column that is not encapsulated in the max function, you should use the GROUP BY operator. That’s why the department field shall be specified in the GROUP BY operator.
PostgreSQL: Calculating Min, Max & Average
About Enteros
Enteros offers a patented database performance management SaaS platform. It proactively identifies root causes of complex business-impacting database scalability and performance issues across a growing number of clouds, RDBMS, NoSQL, and machine learning database platforms.
The views expressed on this blog are those of the author and do not necessarily reflect the opinions of Enteros Inc. This blog may contain links to the content of third-party sites. By providing such links, Enteros Inc. does not adopt, guarantee, approve, or endorse the information, views, or products available on such sites.
Are you interested in writing for Enteros’ Blog? Please send us a pitch!
RELATED POSTS
How to Strengthen Banking Scalability with Enteros RevOps Efficiency and Database Optimization
- 25 May 2026
- Database Performance Management
Introduction The banking industry is undergoing a massive digital transformation as financial institutions accelerate modernization initiatives, expand digital banking services, and adopt cloud-native technologies to improve customer experiences and operational efficiency. Modern banking ecosystems now support: Digital banking platforms Mobile banking applications Payment processing systems Fraud detection environments Real-time analytics platforms Customer engagement systems AI-driven … Continue reading “How to Strengthen Banking Scalability with Enteros RevOps Efficiency and Database Optimization”
How to Optimize Digital Growth Strategies with Enteros AI-Driven Database Software
Introduction Digital transformation has become a strategic priority for organizations across industries as businesses increasingly rely on cloud-native applications, AI-driven analytics, real-time customer engagement platforms, and data-intensive infrastructures to support growth and innovation. Modern enterprises now operate highly connected digital ecosystems involving: Ecommerce platforms SaaS applications Customer engagement systems Real-time analytics environments AI-powered recommendation engines … Continue reading “How to Optimize Digital Growth Strategies with Enteros AI-Driven Database Software”
How Intelligent Database Analytics Transforms Performance in Modern Telecommunications Platforms
The telecommunications industry is experiencing one of the most significant digital transformations in its history. With the rapid expansion of 5G networks, IoT ecosystems, cloud-native infrastructure, edge computing, and real-time digital services, telecom providers are managing unprecedented volumes of data and operational complexity. Modern telecommunications platforms must deliver seamless connectivity, ultra-low latency, uninterrupted service availability, … Continue reading “How Intelligent Database Analytics Transforms Performance in Modern Telecommunications Platforms”
Improving SaaS Platform Reliability and Performance with Advanced Database Monitoring
Modern SaaS platforms operate in an environment where speed, uptime, scalability, and user experience directly impact business growth. Whether it is a CRM platform, collaboration tool, fintech application, healthcare system, or e-commerce SaaS solution, database performance remains the foundation of every digital interaction. As SaaS ecosystems expand across hybrid and multi-cloud infrastructures, maintaining consistent database … Continue reading “Improving SaaS Platform Reliability and Performance with Advanced Database Monitoring”