Mengoptimumkan Pertanyaan MySQL dengan Offset Besar dalam Klausa LIMIT
Apabila melaksanakan pertanyaan MySQL dengan ofset yang ketara dalam klausa LIMIT, isu prestasi mungkin timbul. Ini boleh menjadi cabaran apabila kaedah berasaskan offset tradisional, seperti SELECT * FROM table LIMIT m, n;, menjadi tidak cekap untuk nilai offset yang besar (cth., lebih 1,000,000).
Penyelesaian: Jadual Pengindeksan untuk Pemetaan Kunci Berjujukan
Untuk mengoptimumkan pertanyaan sedemikian, pendekatan alternatif boleh bekerja. Ini melibatkan penciptaan jadual pengindeksan yang mewujudkan hubungan berjujukan kepada kunci utama dalam jadual sasaran. Dengan menyertai jadual pengindeksan ini ke jadual sasaran dan menggunakan klausa WHERE, adalah mungkin untuk mendapatkan semula baris yang dikehendaki dengan lebih cekap:
Mencipta Jadual Pengindeksan
CREATE TABLE seq ( seq_no INT NOT NULL AUTO_INCREMENT, id INT NOT NULL, PRIMARY KEY (seq_no), UNIQUE (id) );
Memasuki Urutan
TRUNCATE seq; INSERT INTO seq (id) SELECT id FROM mytable ORDER BY id;
Mengambil Baris dengan Offset
SELECT mytable.* FROM mytable INNER JOIN seq USING (id) WHERE seq.seq_no BETWEEN 1000000 AND 1000999;
Dalam contoh ini, 1000 baris diambil daripada offset 1,000,000. Kaedah ini menggunakan jadual pengindeksan untuk memetakan offset yang diingini kepada baris yang betul dalam jadual sasaran, meningkatkan prestasi pertanyaan dengan ketara berbanding pendekatan berasaskan offset tradisional.
Atas ialah kandungan terperinci Bagaimana untuk Mengoptimumkan Pertanyaan MySQL dengan Offset Besar dalam Klausa LIMIT?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!