Rumah >pangkalan data >tutorial mysql >Bagaimanakah Saya Boleh Mempercepatkan Pertanyaan Pengiraan Baris dalam Jadual MySQL Besar?

Bagaimanakah Saya Boleh Mempercepatkan Pertanyaan Pengiraan Baris dalam Jadual MySQL Besar?

DDD
DDDasal
2024-11-19 16:46:03424semak imbas

How Can I Speed Up Row Counting Queries in Large MySQL Tables?

Mempercepatkan Pengiraan Baris dalam MySQL

Masalah:

Pertanyaan MySQL untuk mengira bilangan baris dalam jadual besar atau kumpulkan mereka mengikut lajur tertentu boleh menjadi perlahan apabila jadual berkembang. Malah mengindeks lajur yang digunakan untuk pengumpulan tidak meningkatkan prestasi secara konsisten.

Penerokaan:

Untuk mengoptimumkan pertanyaan ini, pendekatan alternatif tanpa menggunakan caching termasuk:

  • Menggunakan Enjin Storan Berasaskan Lajur: Pendekatan ini boleh meningkatkan kiraan(*) pertanyaan, tetapi boleh menjejaskan prestasi untuk operasi lain.
  • Mengekalkan Jadual Ringkasan: Pencetus boleh mengemas kini jadual ringkasan yang berasingan setiap kali satu baris disisipkan, dipadamkan atau dikemas kini. Pendekatan ini menyediakan kiraan baris segera semasa operasi SELECT.

Pelaksanaan:

Untuk mengekalkan jadual ringkasan, pencetus boilerplate berikut boleh digunakan:

DELIMITER //

CREATE TRIGGER ai_books AFTER INSERT ON books
FOR EACH ROW UPDATE books_cnt SET total = total + 1 WHERE status = NEW.status
//
CREATE TRIGGER ad_books AFTER DELETE ON books
FOR EACH ROW UPDATE books_cnt SET total = total - 1 WHERE status = OLD.status;
//
CREATE TRIGGER au_books AFTER UPDATE ON books
FOR EACH ROW
BEGIN
    IF (OLD.status <> NEW.status)
    THEN
        UPDATE books_cnt SET total = total + IF(status = NEW.status, 1, -1) WHERE status IN (OLD.status, NEW.status);
    END IF;
END
//

Dengan mengekalkan jadual ringkasan, pertanyaan pengiraan baris boleh dilaksanakan dengan banyak lebih pantas, tanpa mengira saiz meja.

Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Mempercepatkan Pertanyaan Pengiraan Baris dalam Jadual MySQL Besar?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
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