zoukankan      html  css  js  c++  java
  • mysql优化理解笔记(持续更新)

    主要包括存储引擎、索引、sql语句

    一、存储引擎

    目前最常见的是InnoDB和MyISAM两个存储引擎

    (1)InnoDB:支持事务处理,提供行级锁、外键约束索引,行锁

    (2)MyISAM:支持全文搜索,表锁

      对于经常需要增删改操作的表建议使用InnoDB,因为有事务处理(要么成功要么失败回滚),而需要大量查询操作的表建议用MyISAM

    二、索引

    索引可以大大提高MySQL的检索速度

      (1)普通索引:由关键字KEY或INDEX定义的索引,唯一任务就是加快访问速率

      (2)唯一索引:索引列的值必须唯一,但允许有空值,每个表可以有多个唯一索引,唯一索引不可以被其他表引用为外键

      (3)主键:主键索引是唯一索引的特定类型,它要求主键中的每个值都唯一,并且不能为空,每个表只能有一个主键,可以被其他表引用为外键

    但是索引并不是越多越好,可能加快了select但又减慢了update和insert

      (1)维护重建索引要耗费时间,这种时间会随着数据量的增加而增加

      (2)索引需要占物理空间

      (3)对表的数据进行增删改时,索引需要动态的维护,这样就降低了数据的维护速度

      对于常用where及 order by 的列可以添加索引加快查询速率

    三、sql语句

       (1)select时,不要用*,而是写需要获取的字段名,避免获取多余的数据浪费资源

       (2)select时,避免在 where 子句中使用 or 来连接条件,可以用union。select id from player where status=1 union select id from player where status=2;

       (3)尽量使用union all替代union,因为当结果集很大的时候,还要去移除重复的记录会很浪费资源,如果需要数据唯一的话,可以添加唯一索引

       (4)尽量使用inner join替代left join,因为inner join的效率更高,它只需选出能匹配的记录,不需要返回左表不能匹配的项

       (4)select时,where子句对表字段避免用对null值判断,尽量设置字段默认值为 0或其他

       (5)用exist和not exist 替换in和not in

       (6)避免在where查询时进行表达式操作

       (7)使用join代替子查询

       (8)可以使用explain分析sql执行效率

       (9)可以查看慢查询日志,查看哪些sql比较慢,对应进行修改,

          用set profiling=1;设置慢查询日志开启,

          用show profiles;查看慢查询日志内容,

          用show profile for query id值;查看具体的花费时间

  • 相关阅读:
    Graphics—对话框操作
    Visual Studio 2013 出现error C4996(fopen函数出错)如何解决
    Visual Studio 2013出现错误LNK 2026(SAFESEH模块不兼容)如何解决
    Graphics—菜单设置笔记
    kali 根目录中文乱码
    sqlite文件损坏修复
    win10,mysql安装
    flask 对从数据库反向生成的表进行修改
    flask第一章:项目环境搭建
    flask 连接数据各种报错
  • 原文地址:https://www.cnblogs.com/legendheng/p/9108758.html
Copyright © 2011-2022 走看看