Preamble
PostgreSQL ORDER BY statement is used to sort records in your result set. ORDER BY can only be used in the SELECT operator.
The syntax for ORDER BY statement in PostgreSQL
SELECT_id
FROM tabs
[WHERE conds]
ORDER BY expression_id [ASC | DESC | USING operator] [NULLS FIRST | NULLS LAST];
Parameters and arguments of the statement
- expressions_id – The table or calculations that you want to get.
- tabs – The tables from which you want to get the records. The FROM operator must specify at least one table.
- WHERE conds – Optional. The conditions that must be met for the entries to be selected.
- ASC – Optional. It sorts the reuser set in ascending order (by default, if no modifier is specified).
- DESC is optional. It sorts the result set in descending order by.
- NULLS FIRST – Optional. If specified, all NULL values are sorted before values other than NULL in the resulting set.
- NULLS LAST – Optional. If specified, all NULL values are sorted after values other than NULL in the resulting set.
Note:
- If the ASC or DESC modifier is not specified in ORDER BY, the results will be sorted by expression in ascending order. This is equivalent to ORDER BY expression ASC.
Sorting without using the ASC / DESC attribute
PostgreSQL operator ORDER BY can be used without ASC or DESC modifier. When this attribute is omitted in ORDER BY operator, the sort order is set to ASC (in ascending order) by default.
For example:
SELECT last_name, first_name
FROM contacts
WHERE state = 'California'
ORDER BY last_name;
This example will return all records sorted by last_name field in ascending order and will be equivalent to the next ORDER BY operator:
SELECT last_name, first_name
FROM contacts
WHERE state = 'California'
ORDER BY last_name ASC;
Most programmers skip the ASC attribute when sorting in ascending order.
Sorting in descending order
When sorting a set of results in descending order, you use the DESC attribute in ORDER BY as follows:
SELECT last_name, first_name, city
FROM contacts
WHERE first_name = 'Nikol'
ORDER BY last_name DESC;
In this PostgreSQL example, ORDER BY will return all records sorted by the last_name field in descending order.
Sort by the relative position
You can also use PostgreSQL operator ORDER BY to sort by relative position (order position) in the result set, where the first field in the result set is 1. The next field equals 2, etc.
For example:
SELECT last_name, first_name, city
FROM contacts
WHERE first_name = 'Elena'
ORDER BY 3 DESC;
This PostgreSQL ORDER BY will return all records sorted by the city field in descending order since the city field is at position 3 in the resulting set and will be equivalent to the next ORDER BY:
SELECT last_name, first_name, city
FROM contacts
WHERE first_name = 'Elena'
ORDER BY city DESC;
Use of ASC and DESC attributes
When sorting a set of results with PostgreSQL operator ORDER BY you can use ASC and DESC attributes in one SELECT operator.
For example:
SELECT last_name, first_name, city
FROM contacts
WHERE first_name = 'Elena'
ORDER BY last_name ASC, first_name DESC;
This PostgreSQL ORDER BY will return all records sorted by last_name field in ascending order, with secondary sorting by first_name in descending order.
PostgreSQL: Order By | Course
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 Modern Financial Institutions Improve Data Infrastructure with Intelligent Database Analytics
- 6 May 2026
- Database Performance Management
The financial services industry has rapidly evolved into a highly digital and data-driven ecosystem. Modern financial institutions—including banks, fintech companies, and payment providers—depend heavily on data infrastructure to power services such as digital banking, mobile payments, fraud detection, algorithmic trading, and customer analytics. Every interaction within these platforms generates data that must be processed, analyzed, … Continue reading “How Modern Financial Institutions Improve Data Infrastructure with Intelligent Database Analytics”
How to Transform Media Sector Performance with Enteros Cost Estimation, Cost Attribution, and RevOps Efficiency
Introduction The media sector is experiencing a rapid transformation driven by digital platforms, streaming services, real-time content delivery, and data-driven audience engagement. From OTT platforms and digital publishing to live broadcasting and advertising ecosystems, media organizations must operate at scale while delivering high-quality, personalized experiences. However, this evolution comes with significant challenges. Massive volumes of … Continue reading “How to Transform Media Sector Performance with Enteros Cost Estimation, Cost Attribution, and RevOps Efficiency”
Building Resilient Financial Data Platforms with AI-Driven Database Analytics
Financial institutions are experiencing an unprecedented wave of digital transformation. From mobile banking and digital wallets to real-time payments and algorithmic trading, modern financial services rely heavily on high-performing and resilient data platforms. At the heart of these platforms lies the database infrastructure that powers transactions, customer interactions, and data-driven decision-making. However, as financial platforms … Continue reading “Building Resilient Financial Data Platforms with AI-Driven Database Analytics”
How to Drive Manufacturing Sector Growth with Enteros Database Software, AIOps, Cloud FinOps, and RevOps Alignment
Introduction The manufacturing sector is undergoing a profound transformation fueled by Industry 4.0, smart factories, IoT-enabled production lines, and data-driven decision-making. Modern manufacturers are no longer just focused on production—they are building intelligent ecosystems that integrate operations, supply chains, and customer experiences. However, as manufacturing becomes increasingly digitized, organizations face growing challenges. Massive volumes of … Continue reading “How to Drive Manufacturing Sector Growth with Enteros Database Software, AIOps, Cloud FinOps, and RevOps Alignment”