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 to Improve Retail Profitability with Enteros Cost Attribution, Database Analytics, and Software Management
- 21 June 2026
- Software Engineering
Introduction The retail industry is evolving at an unprecedented pace. Driven by ecommerce growth, omnichannel experiences, customer personalization, and digital transformation initiatives, retailers are investing heavily in technology to remain competitive. Modern retail organizations rely on: Ecommerce platforms Point-of-sale (POS) systems Inventory management applications Customer engagement platforms Supply chain systems Retail analytics environments AI-powered recommendation … Continue reading “How to Improve Retail Profitability with Enteros Cost Attribution, Database Analytics, and Software Management”
How to Drive Education Platform Growth with Enteros Database Performance Analytics and RevOps Efficiency
Introduction The education sector is experiencing a profound digital transformation. Universities, colleges, online learning providers, K-12 institutions, and corporate learning platforms are increasingly relying on technology to deliver engaging learning experiences, manage academic operations, and support student success. Modern education ecosystems now support: Learning Management Systems (LMS) Student Information Systems (SIS) Online learning platforms Virtual … Continue reading “How to Drive Education Platform Growth with Enteros Database Performance Analytics and RevOps Efficiency”
Why Intelligent Database Workload Management Is Essential for High-Growth SaaS Platforms
- 19 June 2026
- Database Performance Management
Introduction Telecommunications providers are operating in one of the most competitive and technology-intensive industries in the world. While demand for connectivity, mobile services, broadband access, and digital experiences continues to grow, profit margins are increasingly challenged by rising infrastructure costs, complex network operations, and expanding customer expectations. Modern telecom organizations must support: 5G networks Cloud-native … Continue reading “Why Intelligent Database Workload Management Is Essential for High-Growth SaaS Platforms”
Reducing Operational Complexity with AI-Driven Database Observability and AIOps
Modern enterprises operate in increasingly complex digital environments. Applications now span hybrid cloud infrastructures, multi-cloud deployments, containerized platforms, microservices architectures, and globally distributed data systems. While this transformation enables greater scalability, agility, and innovation, it also creates significant operational challenges for IT and engineering teams. At the heart of these complex environments lies the database … Continue reading “Reducing Operational Complexity with AI-Driven Database Observability and AIOps”