Let's talk about the various sortings of ORDER BY in ORACLE
This article brings you relevant knowledge about Oracle, which mainly introduces issues related to multiple sorting of ORDER BY, including sorting by a single field, sorting by multiple fields, Sort by substring, etc. I hope this helps everyone.
Recommended tutorial: "Oracle Learning Tutorial"
1. Sort by a single field
Ascending order: ORDER BY ASC (default)
Descending order: ORDER BY DESC
Return query results in the specified order. When actually extracting data or generating reports, you generally have to view them in a certain order. For example, if you want to view Information about employees employed by the unit.
SELECT empno, ename, hiredate FROM emp WHERE deptno = 10 ORDER BY hiredate ASC;
Many people can write this kind of statement to sort query results, but in addition to "ORDER BY hiredate ASC", it can also be written as "ORDER BY 3 ASC" , meaning sort by the third column.
SELECT empno, ename, hiredate FROM emp WHERE deptno = 10 ORDER BY 3 ASC;
When the value is uncertain, it is very convenient to use this method. It should be noted that
Using data to replace the column position can only be used in the order by clause. , cannot be used elsewhere
2. Sort by multiple fields
What should I do if I sort by multiple columns and there is an increase or decrease? For example, when sorting by department number in ascending order and salary in descending order, there are two keywords: ASC means ascending order and DESC means descending order. So we add two columns after order by and mark ASC and DESC respectively.
SELECT empno, deptno, sal, ename, job FROM emp ORDER BY 2 ASC, 3 DESC;
The following is introduced in the form of a diagram, as shown in the figure below. When sorting multiple columns, if the previous column has duplicate values (such as deptno = 10, there are 3 rows of data ), the subsequent sorting is only useful. It is equivalent to dividing the data into several groups by the previous columns, and then sorting the data of each group by the following columns.
3. Sort by substring
Sort by substring There is a quick way to record the customer phone number in the order of the last number, so that when searching You can quickly narrow the scope of your query and enhance customer recognition. If you want to sort in this way, what should you do? Just use the function to get out the required information for the next few bits.
SELECT last_name AS 名称, phone_number AS 号码, salary as 工资, substr(phone_number, -4) AS 尾号 FROM hr.employees WHERE rownum < 5 ORDER BY 4;
It can be seen that as long as the data can be queried, it can be sorted according to the corresponding information.
4. TRANSLATE
Syntax format: TRANSLATE(expr, from_string, to_string)
Examples are as follows:
SELECT TRANSLATE( 'ab 你好 bcadefg', 'abcdefg', '1234567' ) AS NEW_STR FROM DUAL;
from_string and to_string are in character units, and the corresponding characters are replaced one by one.
If to_string is empty, return a null value
SELECT TRANSLATE( 'ab 你好 bcadefg', 'abcdefg', '' ) AS NEW_STR FROM DUAL;
If there is no character in the corresponding position of to_string, delete from_string The characters listed in will be deleted.
SELECT TRANSLATE( 'ab 你好 bcadefg', '1abcdefg', '1' ) AS NEW_STR FROM DUAL;
5. Sort by letters in a mixed string of numbers and letters
First create a VIEW as follows:
CREATE OR REPLACE VIEW V as SELECT empno || ' ' || ename AS data FROM emp;
select * from V;
This requirement is a little more difficult. Do you see the letters inside (that is, the original column ename)? Requires alphabetical ordering within it (column ename).
Then we need to remove the letters first. We can use the replace function of translate to replace the numbers and spaces with empty spaces:
SELECt data, translate (data, '- 0123456789', '-' )AS ename FROM v ORDER BY 2;
6. Handling sorted null values
Oracle sorts null values at the back by default. What if you want to display null values (such as emp.comm) at the front? Do you use NVL (comm, -1)?
SELECT ename, sal, comm, nvl(comm, - 1) order_col FROM emp ORDER BY 4;
也许很多人都是用的这种方法,但这种方法需要对列类型及其中保存的数据有所了解才行,而且保存的数据如果有变化,该语句就要重新维护。
其实可以用关键字 NULLS FIRST和 NULLS LAST。
空值在前
SELECT ename, sal, comm FROM emp ORDER BY 3 NULLS FIRST;
空值在后
SELECT ename, sal, comm FROM emp ORDER BY 3 NULLS LAST;
是不是要方便得多?
7. 根据条件取不同列中的值来排序
有时排序的要求会比较复杂,比如:领导对工资在1000到2000元之间的员工更感兴趣,于是要求工资在这个范围的员工要排在前面,以便优先査看。
对于这种需求,我们可以在查询中新生成一列,用多列排序的方法处理:
SELECT empno AS 编码, ename AS 姓名, CASE WHEN sal > 1000 AND sal < 2000 THEN 1 ELSE 2 END AS 级别, sal AS工资 FROM emp WHERE deptno = 30 ORDER BY 3, 4;
可以看到,950与2850都排在了后面,也可以不显示级别,直接把 case when放在order by中
SELECT empno AS 编码, ename AS 姓名, sal AS工资 FROM emp WHERE deptno = 30 ORDER BY CASE WHEN sal >= 1000 AND sal < 2000 THEN 1 ElSE 2 END, 3;
推荐教程:《Oracle教程》
The above is the detailed content of Let's talk about the various sortings of ORDER BY in ORACLE. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

The retention period of Oracle database logs depends on the log type and configuration, including: Redo logs: determined by the maximum size configured with the "LOG_ARCHIVE_DEST" parameter. Archived redo logs: Determined by the maximum size configured by the "DB_RECOVERY_FILE_DEST_SIZE" parameter. Online redo logs: not archived, lost when the database is restarted, and the retention period is consistent with the instance running time. Audit log: Configured by the "AUDIT_TRAIL" parameter, retained for 30 days by default.

The function in Oracle to calculate the number of days between two dates is DATEDIFF(). The specific usage is as follows: Specify the time interval unit: interval (such as day, month, year) Specify two date values: date1 and date2DATEDIFF(interval, date1, date2) Return the difference in days

The Oracle database startup sequence is: 1. Check the preconditions; 2. Start the listener; 3. Start the database instance; 4. Wait for the database to open; 5. Connect to the database; 6. Verify the database status; 7. Enable the service (if necessary ); 8. Test the connection.

The amount of memory required by Oracle depends on database size, activity level, and required performance level: for storing data buffers, index buffers, executing SQL statements, and managing the data dictionary cache. The exact amount is affected by database size, activity level, and required performance level. Best practices include setting the appropriate SGA size, sizing SGA components, using AMM, and monitoring memory usage.

The INTERVAL data type in Oracle is used to represent time intervals. The syntax is INTERVAL <precision> <unit>. You can use addition, subtraction, multiplication and division operations to operate INTERVAL, which is suitable for scenarios such as storing time data and calculating date differences.

To find the number of occurrences of a character in Oracle, perform the following steps: Get the total length of a string; Get the length of the substring in which a character occurs; Count the number of occurrences of a character by subtracting the substring length from the total length.

The method of replacing strings in Oracle is to use the REPLACE function. The syntax of this function is: REPLACE(string, search_string, replace_string). Usage steps: 1. Identify the substring to be replaced; 2. Determine the new string to replace the substring; 3. Use the REPLACE function to replace. Advanced usage includes: multiple replacements, case sensitivity, special character replacement, etc.

Oracle database server hardware configuration requirements: Processor: multi-core, with a main frequency of at least 2.5 GHz. For large databases, 32 cores or more are recommended. Memory: At least 8GB for small databases, 16-64GB for medium sizes, up to 512GB or more for large databases or heavy workloads. Storage: SSD or NVMe disks, RAID arrays for redundancy and performance. Network: High-speed network (10GbE or higher), dedicated network card, low-latency network. Others: Stable power supply, redundant components, compatible operating system and software, heat dissipation and cooling system.
