Rumah > pangkalan data > tutorial mysql > Mengapa pertanyaan \'SELECT COUNT(*) FROM change_event\' saya sangat perlahan walaupun menggunakan indeks utama?

Mengapa pertanyaan \'SELECT COUNT(*) FROM change_event\' saya sangat perlahan walaupun menggunakan indeks utama?

Susan Sarandon
Lepaskan: 2024-10-30 22:43:29
asal
1169 orang telah melayarinya

Why is my

Prestasi Perlahan dengan Pertanyaan "SELECT COUNT(*)" Walaupun Penggunaan Indeks

Konteks:

Pertanyaan "PILIH COUNT(*) DARI change_event me WHERE change_event_id > '1212281603783391';" berprestasi sangat perlahan dalam MySQL, mengambil masa lebih seminit untuk dilaksanakan. Ini berlaku walaupun terdapat indeks UTAMA pada lajur "change_event_id".

Kunci Utama Berkelompok InnoDB:

Dalam InnoDB, kunci utama dikelompokkan, bermakna ia adalah disimpan bersama baris data dalam halaman data. Ini memerlukan pengimbasan melalui data baris yang berpotensi besar semasa imbasan julat, yang boleh mengurangkan prestasi. Jadual "change_event" mengandungi lajur TEXT, meningkatkan lagi lebar baris.

Teknik Pengoptimuman:

  • Jadual Optimumkan: Menjalankan "OPTIMIZE TABLE" boleh menyusun semula halaman data untuk diisih mengikut kunci utama. Ini berpotensi meningkatkan prestasi imbasan julat pada kunci utama berkelompok.
  • Buat Indeks Bukan Utama Tambahan: Mencipta indeks bukan utama semata-mata pada lajur "change_event_id" boleh memberikan cara yang lebih pantas untuk mengimbas julat nilai. Pelan explain hendaklah disemak selepas mencipta indeks untuk memastikan penggunaannya.

Syor Tambahan:

  • Laraskan Jenis Data: Jika lajur "change_event_id" meningkat daripada sifar, pertimbangkan untuk menukar jenis datanya kepada "bigint unsigned" untuk mengelakkan nilai negatif.

Atas ialah kandungan terperinci Mengapa pertanyaan \'SELECT COUNT(*) FROM change_event\' saya sangat perlahan walaupun menggunakan indeks utama?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
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
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan