

| type | possible_keys | key | key_len | ref | rows | Extra |
|---|---|---|---|---|---|---|
| ALL | (NULL) | (NULL) | (NULL) | (NULL) | 4076607 | |
| type | possible_keys | key | key_len | ref | rows | Extra |
|---|---|---|---|---|---|---|
| PRIMARY | range | PRIMARY | PRIMARY | 4 | 2038331 | Using where |
| SUBQUERY | index | (NULL) | PRIMARY | 4 | 4076663 | Using index |
可以看出,通过子查询的方式,子查询是在索引上进行的,而普通的查询是在数据文件上进行的。 通常来说,索引文件要比数据文件小的多,所以操作索引文件更直接高效。
此外,还可以通过join分页方式
SELECT * FROM `user` AS t1 JOIN (SELECT id FROM `user` ORDER BY id LIMIT 100000, 1) AS t2 WHERE t1.id <= t2.id ORDER BY t1.id LIMIT 10;
join分页和子查询分页的效率基本在一个等级上。(但是,子查询需要在内存中建立临时表,查询完毕后,MySQL需要撤销这些临时表。通过join可以避免这种情况)在分页查询前,可以进行判断,如果是在限定页数内,就使用基本分页查询,大于则使用子查询分页处理。
相关推荐:
mysql分页性能探索
MySQL分页优化的测试案例
MySQL分页性能优化指南
