SQL ORDER BY clause
ORDER BY clause
The ORDER BY clause orders or sorts the result of a query according to the values in one or more specific columns. More than one columns can be ordered one within another. It depends on the user that, whether to order them in ascending or descending order. The default order is ascending.
The SQL ORDER BY clause is used with the SQL SELECT statement.
Note: SQL ORDER BY clause always come at the end of a SELECT statement.
Syntax:
SELECT <column_list> FROM < table name >. WHERE <condition> ORDER BY <columns> [ASC | DESC];
Parameters:
Name | Description |
---|---|
table_name | Name of the table. |
column_list | Name of the columns of the table. |
columns | Name of the columns which will participate in ordering. |
Syntax diagram: SELECT query
Some important questions related to the SQL ORDER BY clause:
What is the purpose of the SQL ORDER BY clause?
What are some common use cases for the ORDER BY clause?
What is the default sorting order in SQL if no explicit order is specified using ORDER BY?
How to sort data in descending order using the ORDER BY clause?
Is it possible to use the ORDER BY clause without specifying any column?
Can you sort data based on multiple columns using the ORDER BY clause?
Can you use column aliases in the ORDER BY clause?
In which position of the SELECT statement does the ORDER BY clause come?
Is it possible to sort data based on expressions or functions using the ORDER BY clause?
What is the difference between the WHERE clause and the ORDER BY clause?
Example: SQL ORDER BY clause - Sorting on column names
Find the agent name, working area and commision; sort the result by agent code ascending order.
Sample table: agents
+------------+----------------------+--------------------+------------+-----------------+---------+ | AGENT_CODE | AGENT_NAME | WORKING_AREA | COMMISSION | PHONE_NO | COUNTRY | +------------+----------------------+--------------------+------------+-----------------+---------+ | A007 | Ramasundar | Bangalore | 0.15 | 077-25814763 | | | A003 | Alex | London | 0.13 | 075-12458969 | | | A008 | Alford | New York | 0.12 | 044-25874365 | | | A011 | Ravi Kumar | Bangalore | 0.15 | 077-45625874 | | | A010 | Santakumar | Chennai | 0.14 | 007-22388644 | | | A012 | Lucida | San Jose | 0.12 | 044-52981425 | | | A005 | Anderson | Brisban | 0.13 | 045-21447739 | | | A001 | Subbarao | Bangalore | 0.14 | 077-12346674 | | | A002 | Mukesh | Mumbai | 0.11 | 029-12358964 | | | A006 | McDen | London | 0.15 | 078-22255588 | | | A004 | Ivan | Torento | 0.15 | 008-22544166 | | | A009 | Benjamin | Hampshair | 0.11 | 008-22536178 | | +------------+----------------------+--------------------+------------+-----------------+---------+
To get 'agent_name', 'agent_name','working_area' and 'commission' from the 'agents' table with following condition -
1. 'agent_code' should come in ascending order,
the following SQL statement can be used:
-- This SQL query retrieves specific columns from the 'agents' table and sorts the result set by the 'agent_code' column.
-- SELECT statement begins
SELECT
agent_code, -- Select the 'agent_code' column from the 'agents' table
agent_name, -- Select the 'agent_name' column from the 'agents' table
working_area, -- Select the 'working_area' column from the 'agents' table
commission -- Select the 'commission' column from the 'agents' table
FROM
agents -- Retrieve data from the 'agents' table
ORDER BY
agent_code; -- Sort the result set by the 'agent_code' column in ascending order
Explanation:
- This SQL code is a SELECT statement that retrieves specific columns from the 'agents' table.
- The columns selected are 'agent_code', 'agent_name', 'working_area', and 'commission'.
- The data is retrieved from the 'agents' table.
- The result set is sorted in ascending order based on the 'agent_code' column using the ORDER BY clause.
- The query does not filter or manipulate the data further; it simply retrieves and sorts the specified columns from the 'agents' table.
Relational Algebra Expression:
Relational Algebra Tree:
Output:
Visual Presentation: SQL ORDER BY ascending - descending
Example: SQL - Usage of the ORDER BY clause with the DESC argument
To get 'agent_name', 'agent_name','working_area' and 'commission' from the 'agents' table with following condition -
1. 'agent_code' should come in descending order,
then, the following SQL statement can be used :
-- This SQL query retrieves specific columns from the 'agents' table and sorts the result set by the 'agent_code' column in descending order.
-- SELECT statement begins
SELECT
agent_code, -- Select the 'agent_code' column from the 'agents' table
agent_name, -- Select the 'agent_name' column from the 'agents' table
working_area, -- Select the 'working_area' column from the 'agents' table
commission -- Select the 'commission' column from the 'agents' table
FROM
agents -- Retrieve data from the 'agents' table
ORDER BY
agent_code DESC; -- Sort the result set by the 'agent_code' column in descending order
Explanation:
- This SQL code is a SELECT statement that retrieves specific columns from the 'agents' table.
- The columns selected are 'agent_code', 'agent_name', 'working_area', and 'commission'.
- The data is retrieved from the 'agents' table.
- The result set is sorted in descending order based on the 'agent_code' column using the ORDER BY clause with the DESC keyword.
- The query does not filter or manipulate the data further; it simply retrieves and sorts the specified columns from the 'agents' table.
Relational Algebra Expression:
Relational Algebra Tree:
Output:
Example: SQL - Ordering by more than one columns
You can use the ORDER BY clause to sort the result of a query according to the values in more than one columns.
To get 'agent_name', 'agent_name','working_area' and 'commission' from the 'agents' table with following conditions -
1. 'working_area' should come in ascending order first,
2. within the same 'working_area', 'agent_code' should come in ascending order,
then, the following SQL statement can be used :
-- This SQL query retrieves specific columns from the 'agents' table and sorts the result set first by the 'working_area' column and then by the 'agent_code' column.
-- SELECT statement begins
SELECT
agent_code, -- Select the 'agent_code' column from the 'agents' table
agent_name, -- Select the 'agent_name' column from the 'agents' table
working_area, -- Select the 'working_area' column from the 'agents' table
commission -- Select the 'commission' column from the 'agents' table
FROM
agents -- Retrieve data from the 'agents' table
ORDER BY
working_area, -- Sort the result set first by the 'working_area' column
agent_code; -- Sort the result set then by the 'agent_code' column
Explanation:
- This SQL code is a SELECT statement that retrieves specific columns from the 'agents' table.
- The columns selected are 'agent_code', 'agent_name', 'working_area', and 'commission'.
- The data is retrieved from the 'agents' table.
- The result set is sorted first by the 'working_area' column in ascending order, and then by the 'agent_code' column in ascending order.
- Sorting by multiple columns allows for more granular control over the order of the result set, first sorting by 'working_area' and then by 'agent_code'.
- The query does not filter or manipulate the data further; it simply retrieves and sorts the specified columns from the 'agents' table.
Relational Algebra Expression:
Relational Algebra Tree:
Output:
Example: SQL - Ordering by more than one columns in ascending or descending order
You can use the ORDER BY clause to sort the result of a query on multiple columns in various order (ascending or descending). Here is an example:
To get 'agent_name', 'agent_name','working_area' and 'commission' from the 'agents' table with following conditions -
1. 'working_area' comes in ascending order first,
2. 'commission' comes in descending order,
then, the following SQL statement can be used :
-- This SQL query retrieves specific columns from the 'agents' table and sorts the result set first by the 'working_area' column in ascending order and then by the 'commission' column in descending order.
-- SELECT statement begins
SELECT
agent_code, -- Select the 'agent_code' column from the 'agents' table
agent_name, -- Select the 'agent_name' column from the 'agents' table
working_area, -- Select the 'working_area' column from the 'agents' table
commission -- Select the 'commission' column from the 'agents' table
FROM
agents -- Retrieve data from the 'agents' table
ORDER BY
working_area ASC, -- Sort the result set first by the 'working_area' column in ascending order
commission DESC; -- Sort the result set then by the 'commission' column in descending order
Explanation:
- This SQL code is a SELECT statement that retrieves specific columns from the 'agents' table.
- The columns selected are 'agent_code', 'agent_name', 'working_area', and 'commission'.
- The data is retrieved from the 'agents' table.
- The result set is sorted first by the 'working_area' column in ascending order and then by the 'commission' column in descending order.
- Sorting by multiple columns allows for more granular control over the order of the result set, first sorting by 'working_area' and then by 'commission'.
- The query does not filter or manipulate the data further; it simply retrieves and sorts the specified columns from the 'agents' table.
Relational Algebra Expression:
Relational Algebra Tree:
Output:
Example: Handle NULL Values
Be mindful of how NULL values are treated during sorting. By default, NULL values usually appear at the end of the sorted result set. However, you can customize this behavior using NULLS FIRST or NULLS LAST in the ORDER BY clause, depending on your requirements.
Suppose we have a table named employees with columns employee_id, employee_name, and salary. Some employees have NULL values in the salary column.
-- Sample employees table
CREATE TABLE employees (
employee_id INT PRIMARY KEY,
employee_name VARCHAR(50),
salary DECIMAL(10, 2)
);
-- Insert sample data
INSERT INTO employees (employee_id, employee_name, salary)
VALUES
(1, 'John Doe', 50000.00),
(2, 'Jane Smith', NULL),
(3, 'Michael Johnson', 75000.00),
(4, 'Emily Davis', 60000.00),
(5, 'Christopher Lee', NULL);
To order the result set by the salary column while handling NULL values, you can use the COALESCE function to replace NULL values with a specific value before sorting:
-- Select all employees and order them by salary (NULL values last)
SELECT
employee_id,
employee_name,
salary
FROM
employees
ORDER BY
COALESCE(salary, 0) DESC; -- Treat NULL values as 0 and sort in descending order
Explanation:
- The COALESCE function is used to replace NULL values in the salary column with 0.
- By sorting in descending order after replacing NULL values with 0, the NULL values will appear at the end of the sorted result set.
- This ensures that employees with NULL salaries are still included in the result set, but they appear after employees with non-NULL salaries.
Output:
+-------------+-----------------+------------+
| employee_id | employee_name | salary |
+-------------+-----------------+------------+
| 3 | Michael Johnson | 75000.00 |
| 4 | Emily Davis | 60000.00 |
| 1 | John Doe | 50000.00 |
| 2 | Jane Smith | NULL |
| 5 | Christopher Lee | NULL |
+-------------+-----------------+------------+
Check out our 1000+ SQL Exercises with solution and explanation to improve your skills.
Previous: SQL character function TRANSLATE
Next: Group By
- Weekly Trends and Language Statistics
- Weekly Trends and Language Statistics