• Mysql优化小技巧


    碎片整理:

    mysql数据一开始是在磁盘上顺序存放的,如果数据表有频繁的update改动,那么数据就会形成很多碎片,拖慢速度和不利于索引;

    优化碎片有两种方式:

    alter table user engine innodb;其实user这个表原先也是innodb的,这句话看上去没有任何意义,但是mysql会重新规整数据

    optimize table user; 也可以修复;

    碎片优化是一种很费cpu和内存的事,最好在夜里执行;

    非常规 的 min  max 优化

    select min(age) from table;

    不管table有多少数据,这条语句都是非常快的,因为mysql内部存到有相关的值,通过explain 可以看出已经被mysql优化过了;

    稍微改一下语句;

    select min(age) from table where status=1;

    通过explain 查看 是全表扫描;

    mysql要一行一行的取出来看status是不是1,如果是,那对比上一次的age看看那个小;有点想冒泡排序一样;

    有个特别的优化方式,要在age有索引的前提下;

    select min(age) from table use index(age) where status=1 limit 1;

    强制mysql使用age索引,因为索引是排好序的,所以取第一个就是最小值,max同理

    count非常规优化

    select count(*) from table;

    通过explain可以看出已经被mysql优化到常亮级别了;非常快

    但是:

    select count(*) from table where id>100;

    速度飞速下降,explain 已查看用到了全表扫描;从100开始扫描全表

    然而这条语句是很快的,只用扫描前100条:

    select count(*) from table where id<100;

    所以优化方法是利用数学加减法:

    ( select count(*) from table ) - ( select  count(*) from table where id<100 )

    union优化:

    连接查询结果的时候 如非必要 尽量使用 union all,因为union all 不过滤数据,效率高,而union要过滤数据,代价很大;

    http://www.cnblogs.com/codeAB/category/650028.html

  • 相关阅读:
    JDBC---bai
    下拉列表---demo---bai
    智能提示框---bai
    国际化---demo1---bai
    自定义数据校验(4)---demo3---bai
    数据校验(3)--demo2---bai
    json概述
    redis持久化
    MyBatis中动态SQL语句完成多条件查询
    Jedis连接redis的一些基本操作
  • 原文地址:https://www.cnblogs.com/XJJD/p/7826520.html
Copyright © 2020-2023  润新知