Analysis of the Poor Performance Caused by Large Offset of LIMIT in MySQL Query

Analysis of the Poor Performance Caused by Large Offset of LIMIT in MySQL Query

Preface

We all know that MySQL query uses the select command, and with the limit and offset parameters, it can read records in a specified range. However, the reason why the offset is too large affects the query performance and the optimization method

We inevitably need paging in our business systems. When you think of paging, you will definitely think of using LIMIT in SQL to implement it. However, incorrect use of LIMIT can lead to performance issues (SQL execution is slow and may bring down the server) and may be criticized by your supervisor; so let's take a look at how to use LIMIT correctly.

Let’s take a look at the detailed introduction.

LIMIT OFFSET, ROW_COUNT to implement paging

Ways to have performance issues

SELECT * FROM myTable ORDER BY `id` LIMIT 1000000, 30

The person who wrote this SQL statement must have thought: the MySQL database will directly locate the 1,000,000th number that meets the conditions, and then fetch 30 pieces of data.
However, this is not how MySQL actually works.

LIMIT 1000000, 30 means: scan 1000030 rows that meet the condition, discard the first 1000000 rows, and then return the last 30 rows.

A better way

SELECT t.*
FROM (
  SELECT id
  FROM myTable
  ORDER BY
    id
  LIMIT 1000000, 30
  ) q
JOIN myTable t
ON t.id = q.id

The general principle is:

  • The subquery only uses the index column and does not fetch actual data, so it does not involve disk IO. Therefore, even with a relatively large offset, the query speed will not be too slow.

Friends who are interested in the specific principle analysis can read this article: MySQL ORDER BY / LIMIT performance: late row lookups

postscript

To be continued.

References

  • Why does MYSQL higher LIMIT offset slow the query down?
  • MySQL ORDER BY / LIMIT performance: late row lookups

Summarize

The above is the full content of this article. I hope that the content of this article will have certain reference learning value for your study or work. If you have any questions, you can leave a message to communicate. Thank you for your support for 123WORDPRESS.COM.

You may also be interested in:
  • Solution to data duplication when using limit+order by in MySql paging
  • Why does MySQL paging become slower and slower when using limit?
  • MySQL optimization query_cache_limit parameter description
  • Detailed explanation of the pitfalls of mixing MySQL order by and limit
  • Reasons and optimization solutions for slow MySQL limit paging with large offsets
  • Mysql sorting and paging (order by & limit) and existing pitfalls
  • MySQL uses limit to implement paging example method
  • How to use MySQL limit and solve the problem of large paging
  • A brief discussion on the performance issues of MySQL paging limit
  • MySQL limit performance analysis and optimization
  • Why does using limit in MySQL affect performance?

<<:  How to monitor Windows performance on Zabbix

>>:  Detailed example of jQuery's chain programming style

Recommend

Introduction to fourteen cases of SQL database

Data Sheet /* Navicat SQLite Data Transfer Source...

MySQL slow_log table cannot be modified to innodb engine detailed explanation

background Getting the slow query log from mysql....

Detailed explanation of tinyMCE usage and experience

Detailed explanation of tinyMCE usage initializat...

Detailed explanation of Vuex overall case

Table of contents 1. Introduction 2. Advantages 3...

Detailed explanation of the use of default in MySQL

NULL and NOT NULL modifiers, DEFAULT modifier, AU...

Basic knowledge of website design: newbies please read this

Now many people are joining the ranks of website ...

XHTML tags have a closing tag

<br />Original link: http://www.dudo.org/art...

MySQL statement execution order and writing order example analysis

The complete syntax of the select statement is: S...

Use html-webpack-plugin' to generate HTML page plugin in memory

When we package the webpackjs file, we introduce ...

Is the tag li a block-level element?

Why can it set the height, but unlike elements lik...

MySQL v5.7.18 decompression version installation detailed tutorial

Download MySQL https://dev.mysql.com/downloads/my...

HTML image img tag_Powernode Java Academy

summary Project description format <img src=&q...

Upgrade Docker version of MySQL 5.7 to MySQL 8.0.13, data migration

Table of contents 1. Back up the old MySQL5.7 dat...

How to install mysql database in deepin 2014 system

Deepin 2014 download and installation For downloa...

Vue element implements table adding, deleting and modifying data

This article shares the specific code of vue elem...