Rumah pangkalan data tutorial mysql 优化mysql的limit offset的例子

优化mysql的limit offset的例子

Jun 07, 2016 pm 05:55 PM
limit offset

在mysql中,通常使用limit做分页,而且经常会跟order by 连用。在order by 上加索引有时候是很有帮助的,不然系统会做很多的filesort

经常碰到的一个问题是limit的offset太高,如:limit 100000,20,这样系统会查询100020条,然后把前面的100000条都扔掉,这是开销很大的操作,导致查询很慢。假设所有分页的页面访问频率一样,这样的查询平均扫描表的一半数据。优化的方法,要么限制访问后面的页数,要么提升高偏移的查询效率。

一个简单的优化办法是使用覆盖查询(covering index)查询,然后再跟全行的做join操作。如:

代码如下:
SQL>select * from user_order_info limit 1000000,5;

这条语句就可以优化为:
代码如下:
select * from user_order_info inner join (select pin from user_order_info limit 1000000,5) as lim using(pin);
SQL>explain select * from user_order_info limit 1000000,5;
+----+-------------+-----------------+------+---------------+------+---------+------+----------+-------+
| id | select_type | table | type | possible_keys | key | key_len | ref | rows | Extra |
+----+-------------+-----------------+------+---------------+------+---------+------+----------+-------+
| 1 | SIMPLE | user_order_info | ALL | NULL | NULL | NULL | NULL | 23131886 | |
+----+-------------+-----------------+------+---------------+------+---------+------+----------+-------+
1 row in set (0.00 sec)
SQL>explain extended select * from user_order_info inner join (select pin from user_order_info limit 1000000,5) as lim using(pin);
+----+-------------+-----------------+--------+---------------+---------+---------+---------+----------+----------+-------------+
| id | select_type | table | type | possible_keys | key | key_len | ref | rows | filtered | Extra |
+----+-------------+-----------------+--------+---------------+---------+---------+---------+----------+----------+-------------+
| 1 | PRIMARY | | ALL | NULL | NULL | NULL | NULL | 5 | 100.00 | |
| 1 | PRIMARY | user_order_info | eq_ref | PRIMARY | PRIMARY | 42 | lim.pin | 1 | 100.00 | |
| 2 | DERIVED | user_order_info | index | NULL | PRIMARY | 42 | NULL | 23131886 | 100.00 | Using index |
+----+-------------+-----------------+--------+---------------+---------+---------+---------+----------+----------+-------------+
3 rows in set, 1 warning (0.66 sec)


根据两个explain的对比,可以清晰发现,第一个未使用索引,扫描了23131886行,第二个也扫描了同样的行数,但是使用了索引,效率提高了。这样可以直接使用index得到数据,而不去查询表,当找到需要的数据之后,在与全表join,获得其他的列。

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Cara Membuka Segala -galanya Di Myrise
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Penjelasan terperinci tentang cara menggunakan ambil dan had dalam Laravel Penjelasan terperinci tentang cara menggunakan ambil dan had dalam Laravel Mar 10, 2024 pm 05:51 PM

"Penjelasan terperinci tentang cara menggunakan ambil dan had dalam Laravel" Dalam Laravel, ambil dan had ialah dua kaedah yang biasa digunakan, digunakan untuk mengehadkan bilangan rekod yang dikembalikan dalam pertanyaan pangkalan data. Walaupun fungsi mereka adalah serupa, terdapat beberapa perbezaan halus dalam senario penggunaan tertentu. Artikel ini akan menganalisis penggunaan kedua-dua kaedah ini secara terperinci dan memberikan contoh kod khusus. 1. Kaedah Ambil Dalam Laravel, kaedah ambil digunakan untuk mengehadkan bilangan rekod yang dikembalikan, biasanya digabungkan dengan kaedah orderBy.

Perbandingan fungsi dan penggunaan ambil dan had dalam Laravel Perbandingan fungsi dan penggunaan ambil dan had dalam Laravel Mar 09, 2024 pm 09:09 PM

Ambil dan hadkan ialah dua kaedah yang biasa digunakan dalam Laravel untuk mengehadkan bilangan set hasil pertanyaan. Walaupun ia mempunyai persamaan tertentu dalam fungsi, ia berbeza dalam penggunaan dan beberapa butiran. Artikel ini akan menjalankan perbandingan terperinci tentang fungsi dan penggunaan kedua-dua kaedah ini, dan menyediakan contoh kod khusus untuk membantu pembaca memahami dengan lebih baik perbezaan antara mereka dan cara menggunakannya dengan betul. 1.kaedah ambil Kaedah ambil adalah dalam pembina pertanyaan LaravelEloquent

Menyelam mendalam tentang perbezaan antara ambil dan had dalam Laravel Menyelam mendalam tentang perbezaan antara ambil dan had dalam Laravel Mar 10, 2024 pm 01:00 PM

Dalam Laravel, kami sering menggunakan beberapa kaedah untuk mengehadkan bilangan hasil pertanyaan, termasuk kaedah ambil dan had. Walaupun kedua-duanya boleh digunakan untuk mengehadkan bilangan hasil pertanyaan, mereka mempunyai beberapa perbezaan yang ketara. Dalam artikel ini, kami akan mendalami cara mengambil dan had berbeza dalam Laravel dan menggambarkannya dengan contoh kod konkrit. Pertama, mari kita lihat kaedah ambil. Kaedah ambil adalah sebahagian daripada Eloquent dan biasanya digunakan untuk

Cara menggunakan had dan langkau fungsi Stream dalam Java untuk operasi strim Cara menggunakan had dan langkau fungsi Stream dalam Java untuk operasi strim Jun 26, 2023 pm 03:55 PM

StreamAPI telah diperkenalkan dalam Java 8, yang boleh memudahkan operasi koleksi. Kelas Strim menyediakan banyak kaedah berfungsi untuk beroperasi pada strim, termasuk penapisan, pemetaan, penggabungan dan banyak lagi. Antaranya, had dan langkau adalah dua fungsi yang digunakan untuk mengehadkan bilangan elemen dalam operasi aliran. 1. Fungsi had Fungsi had digunakan untuk mengehadkan bilangan elemen dalam aliran Ia menerima parameter jenis panjang n, yang mewakili bilangan had. Selepas memanggil fungsi had, aliran baharu dikembalikan, yang hanya mengandungi

Bagaimana untuk menyimpan had Final Fantasy 7 Bagaimana untuk menyimpan had Final Fantasy 7 Mar 07, 2024 pm 06:40 PM

Apabila bermain permainan dalam Final Fantasy 7, pemain boleh menggunakan kemahiran melampau dengan mengumpul had, yang boleh menyebabkan kerosakan besar atau memberikan kesan sokongan yang kuat Pemain boleh mendapatkan had dengan menerima kerosakan, menyerang musuh dan dipukul dalam kombo. Bagaimana untuk menyelamatkan had dalam Final Fantasy 7 1. Mengambil kerosakan Apabila watak diserang oleh musuh atau rakan sepasukan diserang, bar had akan meningkat secara beransur-ansur. Lebih banyak kerosakan yang anda terima, lebih cepat bar had diisi. 2. Menyerang musuh dan secara aktif menyerang musuh juga boleh meningkatkan kelajuan pengisian bar had. Had boleh dikumpul menggunakan serangan biasa, kemahiran atau sihir. 3. Apabila watak kombo hit diserang oleh musuh secara berterusan, kelajuan pengisian bar had akan dipercepatkan. Ini boleh dilakukan dengan menarik perhatian musuh atau dengan menggunakan hold

Notis PHP: Penyelesaian offset yang tidak ditentukan Notis PHP: Penyelesaian offset yang tidak ditentukan Jun 25, 2023 am 09:51 AM

PHPNotice:Undefinedoffset ialah ralat program PHP biasa Ini bermakna program cuba menggunakan subskrip yang tidak wujud dalam tatasusunan, menyebabkan atur cara gagal berjalan seperti biasa. Ralat ini biasanya berlaku apabila penterjemah PHP memaparkan mesej amaran berikut: Notis: Undefinedoffset. Berikut ialah beberapa cara untuk menyelesaikan ralat PHPNotice:Undefinedoffset: Periksa kod Pertama, ia sepatutnya

Pelaksanaan paging MySQL yang berbeza Pelaksanaan paging MySQL yang berbeza Feb 19, 2024 pm 03:26 PM

Apakah kaedah paging dalam MySQL? Contoh kod khusus diperlukan MySQL adalah sistem pengurusan pangkalan data relasi Untuk meningkatkan kecekapan pertanyaan dan mengurangkan jumlah penghantaran data, pertanyaan paging adalah keperluan yang sangat biasa. MySQL menyediakan pelbagai kaedah paging Kaedah ini akan diperkenalkan secara terperinci di bawah dan contoh kod khusus akan disediakan. Paging menggunakan klausa LIMIT: Klausa LIMIT digunakan untuk mengehadkan bilangan baris yang dikembalikan dalam hasil pertanyaan. Ia mempunyai dua parameter Parameter pertama menentukan kedudukan offset permulaan bagi hasil yang dikembalikan (mengira dari 0), dan parameter kedua

Notis PHP: Offset tidak ditentukan: 4 penyelesaian Notis PHP: Offset tidak ditentukan: 4 penyelesaian Jun 22, 2023 pm 04:51 PM

Penyelesaian kepada PHPNotice:Undefinedoffset:4 Dalam proses menulis kod dalam PHP, kami mungkin menghadapi mesej ralat yang serupa dengan "PHPNotice:Undefinedoffset:4". Mesej ralat ini bermakna apabila kami mengakses tatasusunan, kami cuba mengakses elemen yang tidak wujud. Khususnya, jika kita mempunyai array $my_array dengan hanya 3 elemen di dalamnya, dan kami cuba mengakses $my_array

See all articles