加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

Mysql学习Advanced Pagination for MySQL(mysql高级分页)

发布时间:2020-12-12 02:27:49 所属栏目:MySql教程 来源:网络整理
导读:《Mysql学习Advanced Pagination for MySQL(mysql高级分页)》要点: 本文介绍了Mysql学习Advanced Pagination for MySQL(mysql高级分页),希望对您有用。如果有疑问,可以联系我们。 MYSQL学习 在叶子的文章里谈到了使用inner join 从而减少了对page的扫描也

《Mysql学习Advanced Pagination for MySQL(mysql高级分页)》要点:
本文介绍了Mysql学习Advanced Pagination for MySQL(mysql高级分页),希望对您有用。如果有疑问,可以联系我们。

MYSQL学习在叶子的文章里谈到了使用inner join 从而减少了对page的扫描也便是减少了所谓的回表 例如:

代码如下:
SELECT * FROM `t1` INNER JOIN ( SELECT id FROM `t1`ORDER BY id DESC LIMIT 935500,10) t2 USING (id)

MYSQL学习通过直接对id的操作 而不是整张表的扫描 通过id 的join 抓出符合条件id 然后通过ID 再去做数据的抓取.这样就避免了对不必要的页面的扫描.

MYSQL学习不过这样也不是最佳的办法 还可以通过对id 的 range更加缩小范围 例如:

MYSQL学习我们要分100条记录分一页 可以写成

代码如下:
$page_size=100 select * from t where id > 99 order by id asc limit $page_size ; select * from? t where id >199 order by id asc limit $page_size;

MYSQL学习尽量避免limit M,N 这种写法 mysql在对M值很大 而offset很小的时候的处置方式很不人性化,所以尽量不要使用offset来取得特定行数.

MYSQL学习在这里有一个问题 好比根据不是唯一索引的column分页 那么可能存在一个问题,例如一个列column1存在11个key=100的值 那么你使用limit N 之后取到的min value还是同一个值
这种情况如何处理? 给个例子:

MYSQL学习好比要每10条记录分一页

代码如下:
select * from t? order by column1 desc? limit 10

MYSQL学习注意这里取到的min value还是100 (11个连续的100) 对下面的分页会发生影响,如何处理?

MYSQL学习雅虎给出的方案非常好 取一个extra的column 例如PK 或者unique index key 例如:

代码如下:
select * from t? order by column1 desc,id desc?? limit 10 -- 第一个页
select * from t? where column1 <=minvalue_col1 and (id < minvalue_id or column1 < minvalue_col1) limit 10? ---第二个页

MYSQL学习这样就确保了唯一性 保证了每页的数据不会重复 思想就是通过add一个唯一的extra 取得这个extra的界限值 结合range column来进行分页.

MYSQL学习这个SQL 还能被优化成:

代码如下:
SELECT m2.* FROM t m1,t m2? WHERE m1.id = m2.id? AND m1.column1 <= minvalue_col1
AND (m1.id < minvalue_id OR m1.column1 < minvalue_col1)? ORDER BY m1.column1 DESC,m1.id DESC? LIMIT 10;

MYSQL学习核心思想: 通过extra过滤 配合ID扫描 避免大量的回表操作 这样就到达了要取多少条 就扫描多少条 (in page)

欢迎参与《Mysql学习Advanced Pagination for MySQL(mysql高级分页)》讨论,分享您的想法,编程之家PHP学院为您提供专业教程。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读