zoukankan      html  css  js  c++  java
  • 优化分页的查询

    一般分页查询时,通过创建覆盖索引能够比较好的提高性能。一个经常使用的场景:"limit 1000,20",此时MySQL排序出前1020记录后仅仅返回第1001到1020条记录。前1000条记录会被抛弃,查询和排序的代价非常高。

     

    第一种优化思路

    在索引上完成排序分页的操作,最后根据主键关联回原表查询所需要的其他列内容。尽可能扫描少的页面来提高分页的效率。

     explain select film_id,description from film order by title limit 50,5G;

    从输出的结果看:优化器做了全表扫描,处理效率不高。

     优化

    explain select a.film_id,a.description from film a inner join(select film_id from film order by title limit 50,5)b on a.film_id = b.film_idG;

    第二种优化思路

    把limit查询转换成某个位置的查询。如: 第n的最后一条的id为1100,现在需要翻页到n+1页,可以通过前台传入第n页的最后一条记录的id为1100。

  • 相关阅读:
    Shell脚本编程-02-----shell编程之条件语句
    ELK 简介
    Linux 下的网卡文件配置
    Tomcat 简介
    Docker 基本操作
    zabbix 介绍
    CentOS 上搭建 Kubernetes 集群
    Docker 简介
    yum 源的配置安装
    Docker 入门
  • 原文地址:https://www.cnblogs.com/dsitn/p/7120434.html
Copyright © 2011-2022 走看看