MySQL高级性能优化---limit优化

当表中存在大批量数据时分页如何优化?
我们先创建一张employee表, 使用存储过程或者函数创建1000万条数据。

limit查询分析

使用limit随着offset增大,查询的速度会越来越慢。
limit查询会把前边的数据都取出来,比如limit 100000, 10时会把前10万条数据取出找到对应的位置,再取10条数据。因此你的offset的值越大查询的数据就越多
MySQL高级性能优化---limit优化_第1张图片

所以我们对limit进行优化

1. 使用子查询优化limit查询

MySQL高级性能优化---limit优化_第2张图片

MySQL高级性能优化---limit优化_第3张图片
MySQL高级性能优化---limit优化_第4张图片

使用子查询优化limit归根结底还是基于索引快速查询,让耗时的查询走索引

2. 使用id限定优化

记录上一页最大的id号,使用范围查询。限定是只能使用于明确知道id的情况,不过一般建立表的时候,都会添加基本的id字段,这为分页查询带来很多便利。但是唯一的缺陷是id这一列必须是自增的。而且id这一列数据不能乱

MySQL高级性能优化---limit优化_第5张图片
MySQL高级性能优化---limit优化_第6张图片

你可能感兴趣的:(mysql)