Preamble
The min function in PostgreSQL returns the minimum value of the expression.
Syntax of the min function in PostgreSQL
SELECT min(aggregate_expression_id)
FROM tabs
[WHERE conds];
Or the syntax of the min function when grouping the results into one or more columns:
SELECT expression1_id,2_id,..._n_id,
min(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 min function and must be included in the GROUP BY operator at the end of the SQL query.
- aggregate_expression_id – This is a column or expression from which the minimum 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 conds – Optional. These are the conditions that must be met to select records.
The min 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
Consider some examples of min functions to understand how to use the min function in PostgreSQL.
For example, you can find out how the minimum value is in the inventory table.
SELECT min(quantity) AS "Lowest Quantity"
FROM inventory;
In this example of the min function, we called the expression min(quantity) as “Lowest Quantity”. As a result, “Lowest Quantity” will be displayed as the field name when the result set returns.
Example using GROUP BY
In some cases, you will need to use GROUP BY operator with min function.
For example, you can also use the min function to return values in the department field and the min(quantity) field from the inventory table.
SELECT department, min(quantity) AS "Lowest Quantity"
FROM inventory
GROUP BY department;
Since your SELECT operator has one column that is not encapsulated in the min function, you must use the GROUP BY operator. That is why the department field should 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
Transforming Healthcare Data Systems with Intelligent Database Analytics
- 22 April 2026
- Database Performance Management
The healthcare industry is undergoing a massive digital transformation. Hospitals, clinics, research institutions, and healthcare technology companies are increasingly relying on data-driven systems to deliver faster diagnoses, improve patient outcomes, and enhance operational efficiency. From Electronic Health Records (EHR) and telemedicine platforms to AI-powered diagnostics and real-time clinical analytics, modern healthcare systems generate enormous volumes … Continue reading “Transforming Healthcare Data Systems with Intelligent Database Analytics”
Improving Retail Operations with Database Performance Analytics
The retail industry is evolving at an unprecedented pace. From omnichannel shopping experiences and personalized recommendations to AI-powered inventory management and real-time analytics, retailers now rely heavily on advanced data infrastructure. Every customer interaction—whether online, in-store, or via mobile apps—generates valuable data that must be processed quickly and efficiently. However, managing large volumes of retail … Continue reading “Improving Retail Operations with Database Performance Analytics”
How to Optimize Technology Sector Growth with Enteros Database Management Platform, Cost Attribution, and Database Software
- 21 April 2026
- Database Performance Management
Introduction The technology sector is evolving at an unprecedented pace, driven by cloud computing, artificial intelligence, SaaS platforms, and real-time digital services. Organizations are scaling rapidly to meet global demand, but with this growth comes increasing complexity in managing infrastructure, controlling costs, and maintaining high-performance systems. Technology companies today must balance innovation with efficiency. While … Continue reading “How to Optimize Technology Sector Growth with Enteros Database Management Platform, Cost Attribution, and Database Software”
How to Optimize Retail Sector Growth with Enteros Database Management Platform, AIOps, RevOps Efficiency, and Cost Estimation
The retail sector is evolving rapidly, driven by digital transformation, omnichannel experiences, and data-driven decision-making. Retailers today must deliver seamless customer experiences across online platforms, mobile apps, and physical stores—all while managing complex IT systems and rising operational costs. However, this growth comes with a fundamental challenge:how to scale efficiently while maintaining performance, controlling costs, … Continue reading “How to Optimize Retail Sector Growth with Enteros Database Management Platform, AIOps, RevOps Efficiency, and Cost Estimation”