zoukankan      html  css  js  c++  java
  • 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

  • 相关阅读:
    青城的另一个一夜/情
    SystemProperties.get/set property_get/set
    锁——Java同步的基本思想
    CMUSphinx Learn
    猜数字
    我的音乐我的电影
    动态规划_钢条切割问题
    directdraw显示yuv420(YV12)
    Redis 命令参考
    HDU 3078 LCA转RMQ
  • 原文地址:https://www.cnblogs.com/XJJD/p/7826520.html
Copyright © 2011-2022 走看看