search
HomeDatabaseSQL[SQL Learning] The connection between ordered index and order by

Generally, there are two implementation methods for order by. One is to use the ordered index to automatically implement it. That is to say, using the orderliness of the ordered index does not require additional sorting operations. The other is to sort the results after selecting them. Using ordered index is of course the fastest, but there are some restrictions. Let’s take a look at the test below.

Test data: The student table has two fields id, sid, and id is the primary key. There are a total of 20W records, with IDs ranging from 1 to 200000, and sids also ranging from 1 to 200000.

The first situation:

The order by field is neither in the where condition nor in the select

select sid from zhuyuehua.student where sid
[SQL Learning] The connection between ordered index and order by
##Second case:

order by The field is not in the where condition but in the select.

select id,sid from zhuyuehua.student where sid

[SQL Learning] The connection between ordered index and order by
The third case:

The order by field is in the where condition but not in the select.

select sid from zhuyuehua.student where sid

[SQL Learning] The connection between ordered index and order by##Fourth case:

The order by field is in the where condition but not in the select. Sort in reverse order

select sid from zhuyuehua.student where sid


[SQL Learning] The connection between ordered index and order byTest results:

The field of order by is not in the where condition and is not in the select There is a sorting operation

The field of order by is not in the where condition but in select There is a sorting operation

The field of order by is in the where condition but not in the select No sorting operation

The fields of order by are in the where condition but not in the select (reverse order) No sorting operation

Conclusion:


When the order by field appears in the where condition, the index will be used without sorting operation.
In other cases, order by will not perform sorting operations. analyze:


Why only when the order by field appears in the where condition, the index of the field will be used to avoid sorting.
This is about how the database gets the data we need. A SQL can actually be divided into three steps.

1. Get data

2. Process data

3. Return the processed data

For example, the above statement select sid from zhuyuehua.student where sid
Step 1: Generate execution based on where condition and statistical information Plan, get data.

Step 2: Sort the obtained data.


When executing data processing (order by), the database will first check the execution plan of the first step to see whether the fields of order by use indexes in the execution plan. If so, you can use the index order to directly obtain the sorted data.
If not, sort operation. Step 3: Return the sorted data.

in addition:

The above 50,000 data sort only took 25ms. Maybe you think the sort does not take up much resources. However, since the data in the above table is ordered, sorting takes less time. If it is a relatively unordered table, the sort time will increase a lot. In addition, sorting operations are generally performed in memory, which is a kind of CPU consumption for the database. Due to the enhanced performance of the CPU, ordinary sorting of dozens or hundreds of records will not have a great impact on the system. big. But when your record set increases to more than one million records, you need to pay attention to whether you must do this. Sorting of large record sets not only increases CPU overhead, but also may cause hard disk sorting due to insufficient memory. When a hard disk occurs Performance drops dramatically when sorting.

Note: ORACLE or DB2 have a space for SORT operations (the memory sorting mentioned above). For example, in ORACLE, it is the user global area (UGA), which contains settings for parameters such as SORT_AREA_SIZE. If the amount of data being sorted is large, sorting overflow (hard disk sorting) will occur, and the performance will be reduced a lot.

Summarize:



When the fields in order by appear in the where condition, the index will be used without sorting. To be more precise, the fields in order by are in the execution plan When using indexes, no sorting operation is required. #This conclusion is not only valid for order by, but also for other operations that require sorting. For example,

group by, union, distinct, etc.
If you want to know more tutorials about sql, please pay attention to the PHP Chinese website

sql video tutorial

!


  • [SQL Learning] The connection between ordered index and order by
  • Size: 16 KB
  • [SQL Learning] The connection between ordered index and order by
  • Size : 16 KB
  • [SQL Learning] The connection between ordered index and order by
  • Size: 20.6 KB
  • [SQL Learning] The connection between ordered index and order by
  • ##Size : 21 KB

    The above is the detailed content of [SQL Learning] The connection between ordered index and order by. For more information, please follow other related articles on the PHP Chinese website!

    Statement
    This article is reproduced at:CSDN. If there is any infringement, please contact admin@php.cn delete
    SQL: The Learning Curve for BeginnersSQL: The Learning Curve for BeginnersApr 16, 2025 am 12:11 AM

    The SQL learning curve is steep, but it can be mastered through practice and understanding the core concepts. 1. Basic operations include SELECT, INSERT, UPDATE, DELETE. 2. Query execution is divided into three steps: analysis, optimization and execution. 3. Basic usage is such as querying employee information, and advanced usage is such as using JOIN connection table. 4. Common errors include not using alias and SQL injection, and parameterized query is required to prevent it. 5. Performance optimization is achieved by selecting necessary columns and maintaining code readability.

    SQL: The Commands, MySQL: The EngineSQL: The Commands, MySQL: The EngineApr 15, 2025 am 12:04 AM

    SQL commands are divided into five categories in MySQL: DQL, DDL, DML, DCL and TCL, and are used to define, operate and control database data. MySQL processes SQL commands through lexical analysis, syntax analysis, optimization and execution, and uses index and query optimizers to improve performance. Examples of usage include SELECT for data queries and JOIN for multi-table operations. Common errors include syntax, logic, and performance issues, and optimization strategies include using indexes, optimizing queries, and choosing the right storage engine.

    SQL for Data Analysis: Advanced Techniques for Business IntelligenceSQL for Data Analysis: Advanced Techniques for Business IntelligenceApr 14, 2025 am 12:02 AM

    Advanced query skills in SQL include subqueries, window functions, CTEs and complex JOINs, which can handle complex data analysis requirements. 1) Subquery is used to find the employees with the highest salary in each department. 2) Window functions and CTE are used to analyze employee salary growth trends. 3) Performance optimization strategies include index optimization, query rewriting and using partition tables.

    MySQL: A Specific Implementation of SQLMySQL: A Specific Implementation of SQLApr 13, 2025 am 12:02 AM

    MySQL is an open source relational database management system that provides standard SQL functions and extensions. 1) MySQL supports standard SQL operations such as CREATE, INSERT, UPDATE, DELETE, and extends the LIMIT clause. 2) It uses storage engines such as InnoDB and MyISAM, which are suitable for different scenarios. 3) Users can efficiently use MySQL through advanced functions such as creating tables, inserting data, and using stored procedures.

    SQL: Making Data Management Accessible to AllSQL: Making Data Management Accessible to AllApr 12, 2025 am 12:14 AM

    SQLmakesdatamanagementaccessibletoallbyprovidingasimpleyetpowerfultoolsetforqueryingandmanagingdatabases.1)Itworkswithrelationaldatabases,allowinguserstospecifywhattheywanttodowiththedata.2)SQL'sstrengthliesinfiltering,sorting,andjoiningdataacrosstab

    SQL Indexing Strategies: Improve Query Performance by Orders of MagnitudeSQL Indexing Strategies: Improve Query Performance by Orders of MagnitudeApr 11, 2025 am 12:04 AM

    SQL indexes can significantly improve query performance through clever design. 1. Select the appropriate index type, such as B-tree, hash or full text index. 2. Use composite index to optimize multi-field query. 3. Avoid over-index to reduce data maintenance overhead. 4. Maintain indexes regularly, including rebuilding and removing unnecessary indexes.

    How to delete constraints in sqlHow to delete constraints in sqlApr 10, 2025 pm 12:21 PM

    To delete a constraint in SQL, perform the following steps: Identify the constraint name to be deleted; use the ALTER TABLE statement: ALTER TABLE table name DROP CONSTRAINT constraint name; confirm deletion.

    How to set SQL triggerHow to set SQL triggerApr 10, 2025 pm 12:18 PM

    A SQL trigger is a database object that automatically performs specific actions when a specific event is executed on a specified table. To set up SQL triggers, you can use the CREATE TRIGGER statement, which includes the trigger name, table name, event type, and trigger code. The trigger code is defined using the AS keyword and contains SQL or PL/SQL statements or blocks. By specifying trigger conditions, you can use the WHERE clause to limit the execution scope of a trigger. Trigger operations can be performed in the trigger code using the INSERT INTO, UPDATE, or DELETE statement. NEW and OLD keywords can be used to reference the affected keyword in the trigger code.

    See all articles

    Hot AI Tools

    Undresser.AI Undress

    Undresser.AI Undress

    AI-powered app for creating realistic nude photos

    AI Clothes Remover

    AI Clothes Remover

    Online AI tool for removing clothes from photos.

    Undress AI Tool

    Undress AI Tool

    Undress images for free

    Clothoff.io

    Clothoff.io

    AI clothes remover

    AI Hentai Generator

    AI Hentai Generator

    Generate AI Hentai for free.

    Hot Article

    R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
    4 weeks agoBy尊渡假赌尊渡假赌尊渡假赌
    R.E.P.O. Best Graphic Settings
    4 weeks agoBy尊渡假赌尊渡假赌尊渡假赌
    R.E.P.O. How to Fix Audio if You Can't Hear Anyone
    1 months agoBy尊渡假赌尊渡假赌尊渡假赌
    R.E.P.O. Chat Commands and How to Use Them
    1 months agoBy尊渡假赌尊渡假赌尊渡假赌

    Hot Tools

    Atom editor mac version download

    Atom editor mac version download

    The most popular open source editor

    MinGW - Minimalist GNU for Windows

    MinGW - Minimalist GNU for Windows

    This project is in the process of being migrated to osdn.net/projects/mingw, you can continue to follow us there. MinGW: A native Windows port of the GNU Compiler Collection (GCC), freely distributable import libraries and header files for building native Windows applications; includes extensions to the MSVC runtime to support C99 functionality. All MinGW software can run on 64-bit Windows platforms.

    EditPlus Chinese cracked version

    EditPlus Chinese cracked version

    Small size, syntax highlighting, does not support code prompt function

    Dreamweaver Mac version

    Dreamweaver Mac version

    Visual web development tools

    Notepad++7.3.1

    Notepad++7.3.1

    Easy-to-use and free code editor