当使用大偏移量对mysql LIMIT
进行SELECT
编码时,出现性能问题:
SELECT * FROM table LIMIT m, n;
如果偏移
m
大于1,000,000,则操作非常缓慢。我必须使用
limit m, n
;我不能使用类似id > 1,000,000 limit n
的东西。如何优化此语句以获得更好的性能?
最佳答案
也许您可以创建一个索引表,该表提供与目标表中的键相关的顺序键。然后,您可以将此索引表连接到目标表,并使用where子句更有效地获取所需的行。
#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;