Mysql
 sql >> Base de données >  >> RDS >> Mysql

Comment puis-je accélérer une requête MySQL avec un décalage important dans la clause LIMIT ?

Peut-être pourriez-vous créer une table d'indexation qui fournit une clé séquentielle relative à la clé de votre table cible. Ensuite, vous pouvez joindre cette table d'indexation à votre table cible et utiliser une clause where pour obtenir plus efficacement les lignes souhaitées.

#create table to store sequences
CREATE TABLE seq (
   seq_no int not null auto_increment,
   id int not null,
   primary key(seq_no),
   unique(id)
);

#create the sequence
TRUNCATE seq;
INSERT INTO seq (id) SELECT id FROM mytable ORDER BY id;

#now get 1000 rows from offset 1000000
SELECT mytable.* 
FROM mytable 
INNER JOIN seq USING(id)
WHERE seq.seq_no BETWEEN 1000000 AND 1000999;