时间:2021-07-01 10:21:17 帮助过:3人阅读
上述这条SQL语句需要查询10020条记录然后只返回最后20条。前面的10000条记录都将被抛弃,这样代价非常高。
优化此类分类查询的一个最简单的办法就是尽可能地使用索引覆盖扫描(如果一个索引包含(或者说覆盖)所有需要查询的字段的值,我们就称之为“覆盖索引”。可以使用explain查看extra列信息,如果看到“Using index”的信息则说明使用到了覆盖索引。),而不是查询所有的列。然后根据需要做一次关联操作再返回所需的列。对于偏移量很大的时候,这样做的效率会提升非常大。
如上述SQL语句可以修改为:
SELECT id, name FROM A INNER JOIN ( SELECT id FROM A ORDER BY id DESC LIMIT 10000, 20 ) AS tmp USING(id);
这里的“延迟关联”将大大提升查询效率,它让MySQL扫描尽可能少的页面,获取需要访问的记录后再根据关联列回原表查询需要的所有列。
可以使用书签记录上次取数据的位置,那么下次就可以直接从该书签记录的位置开始扫描,这样就可以避免使用OFFSET。
如上一次记录到10000为止,则可以修改为:
SELECT id, name FROM A WHERE id < 10000 ORDER BY id DESC LIMIT 20;
这种方法的好处是无论翻页到多么后面,其性能都会很好。
有时候也可以将LIMIT查询转换为已知位置的查询,让MySQL通过范围扫描获得到对应的结果。
如知道边界值为10000,10020后上述语句可以修改为:
SELECT id , name FROM A WHERE id BETWEEN 10000 AND 10020 ORDER BY id DESC;
除上述方法外,还有一些其它方法,如:
SQL分页过多时, 如何优化
标签:就是 查询 mit code order 获取 字段 关联 数据