一、建库建表优化

1、核心规范(推荐)

  • 表字符集选择UTF8 (“表情”字段单独设置为其他字符集)
  • 存储引擎使用INNODB
  • 不在库中存储图片、文件等
  • 使用可变长字符串(varchar)
  • 每张表数据量控制在5000W以下

2、字段命名规范(建议)

  • 库名、表名、字段名、索引名使用小写字母,以下划线分割
  • 非唯一索引按照“idx_字段名[_字段名]”进行命名
  • 唯一索引按照“uniq_字段名[_字段名]”进行命名(不要直接采用字段名称定义索引名称。防止删除索引时,误删除字段)

3、字段属性规则(建议)

  • 所有字段均定义为 NOT NULL(null会降低索引效果;索引会产生额外的空间)
  • ·使用unsigned存储非负整数
  • ·使用timestamp存储时间(可利用该类型的默认值,进行查询优化)

4、字段类型规则(推荐)

  • 使用tinyint来代替enum类型
  • 尽可能不用text、blob类型
  • 将字符转化为数字
  • 存储 “abcd” 时 varchar(5) 比 varchar(10) 更优

5、索引规则(推荐)

  • 选择自增列作为主键
  • 单表索引数不超过5个、单个索引字段数不超过5个
  • 字符串可使用前缀索引,前缀长度控制在5-8个字符
  • 不在低基数列上建立索引,如:性别、是否删除、是否发布
  • 不使用select * 优化成 select id,name,age……..
  • 不在索引列进行数学运算、函数

6、SQL规范

  • 避免隐式转换
  • 避免使用存储过程、触发器、函数
  • 避免进行数学运算
  • 尽可能拆分大SQL

二、建立高效索引

目的:加速查询、加速排序、覆盖索引(只需要在索引中完成查询,不需要回到表中)

1、主键:和数据存储在一起。

  • 通常选择自增列作为主键
  • 优点:
    • a 顺序插入,不会出现数据页内数据移动的情况发生(插入更快)
    • b 数据存储更紧凑(查询更快)
  • 缺点:
    • 多出4至8字节无意义的数据

2、二级索引:和数据分开存储

  • 二级索引中是按照索引列+主键的对应关系进行存储的,每多一个索引就会多一个这样的对应关系。所以索引的个数越多,占用空间越大,在插入、删除的时候会越慢。

3、什么样的字段适合加索引?

  • 首先,要满足主要功能的查询条件。
  • 其次,要看该字段的唯一值多少。
  • 唯一值: select count(distinct uid)/count(1) from table; 值越大,索引效果越好。

   type  :建议优化的类型

      • system           表只有一行
      • const              用到的是主键或唯一索引
      • eq_ref            多表查询时,匹配到了1行,并且利用的是主键或唯一索引

      • ref                   匹配到了多行,通常是利用的普通索引(如果是联合唯一索引,只用到了其中1个也是这个类型)
      • ref_or_null     与ref类似,条件中用到了 null 的搜索
      • all                   没有用到索引
      • 出现上面所列之外的类型时,如range、index等说明用到的索引性能很差

    rows:

      • 查询影响的行数,值越小越优。

      extra: 

      • 查询的详细信息,类型包括:
      • using where、using index、using filesort等都是正常查询过程
      • using temporary 出现时,说明需要对sql或索引进行优化

二、优化SQL

  • 需要多表查询时,内(外)连接查询不一定是最佳的方案,适当的采用子查询,会是更好的选择。
  • 把 select * 换成部分字段,可少许降低查询时间
  • 垃圾索引只会影响插入、删除效率,对查询速度影响较小。
  • 字段唯一性太低,索引效率不高。
  • 字段唯一性非常高,索引的性能会很优秀。
  • 时间范围很大时,用不到索引。尽可能让时间范围有开口和闭口,区间也不易过大,根据数据量及最早时间来决定。

MySQL 规范及优化的更多相关文章

  1. mysql设计与优化以及数据库表设计与表开发规范

    一.设计问题? 1.主键是用自增还是UUID ? Innodb 中的主键是聚簇索引. 如果主键是自增的,那么每次插入新的记录,记录就会顺序添加到当前索引节点的后续位置,当一页写满,就会自动开辟一个新的 ...

  2. 第 10 章 MySQL Server 性能优化

    前言: 本章主要通过针对MySQL Server(mysqld)相关实现机制的分析,得到一些相应的优化建议.主要涉及MySQL的安装以及相关参数设置的优化,但不包括mysqld之外的比如存储引擎相关的 ...

  3. MySQL查询性能优化(精)

    MySQL查询性能优化 MySQL查询性能的优化涉及多个方面,其中包括库表结构.建立合理的索引.设计合理的查询.库表结构包括如何设计表之间的关联.表字段的数据类型等.这需要依据具体的场景进行设计.如下 ...

  4. MySql(十):MySQL性能调优——MySQL Server性能优化

    本章主要通过针对MySQL Server( mysqld)相关实现机制的分析,得到一些相应的优化建议.主要涉及MySQL的安装以及相关参数设置的优化,但不包括mysqld之外的比如存储引擎相关的参数优 ...

  5. 170727、MySQL查询性能优化

    MySQL查询性能优化 MySQL查询性能的优化涉及多个方面,其中包括库表结构.建立合理的索引.设计合理的查询.库表结构包括如何设计表之间的关联.表字段的数据类型等.这需要依据具体的场景进行设计.如下 ...

  6. 到底该不该使用存储过程 MySQL查询性能优化一则

    到底该不该使用存储过程   看到<阿里巴巴java编码规范>有这样一条 关于这条规范,我说说我个人的看法 用不用存储过程要视所使用的数据库和业务场景而定的,不能因为阿里巴巴的技术牛逼,就视 ...

  7. mysql库表优化实例

    一.SQL优化 1.优化SQL一般步骤 1.1 查看SQL执行频率 SHOW STATUS LIKE 'Com_%'; Com_select:执行SELECT操作的次数,一次查询累加1.其他类似 以下 ...

  8. 基于MySQL 的 SQL 优化总结

    文章首发于我的个人博客,欢迎访问.https://blog.itzhouq.cn/mysql1 基于MySQL 的 SQL 优化总结 在数据库运维过程中,优化 SQL 是 DBA 团队的日常任务.例行 ...

  9. MySQL“被动”性能优化汇总!

    年少不知优化苦,遇坑方知优化难. --村口王大爷 本文内容导图如下: 我之前有很多文章都在讲性能优化的问题,比如下面这些: <switch 的性能提升了 3 倍,我只用了这一招!> < ...

随机推荐

  1. Java使用线程池

    多线程主函数 package UnitTest; import java.util.ArrayList; import java.util.List; import java.util.concurr ...

  2. [原创]Xilinx Vivado 2017.4/2018.3/2016.4/2015.4/ISE14.7下载及其安装

    最新版本Vivado 2018.3下载地址 链接:https://pan.baidu.com/s/17aE-vICRQYN27bD2sXCLxg提取码:ilg5 由于工程需要,下载VIVADO2018 ...

  3. .NET英文技术文章导读(2017-03-23)

    关键字:VS2017.扩展.Service Fabric.Unit Test.ELMAH Web开发人员必装的5个VS2017扩展 作者:Jeffrey T. Fritz 链接:https://blo ...

  4. Virtual box中Ubuntu虚拟机磁盘碎片整理和空间清理方法

    虚拟机中,随着不断的使用,增加大文件(例如日志,视频和软件版本),虽然在虚拟机中手动删除了,但是虚拟机占用的空间并不会随之减少,需要手动清理一下. 这里介绍一种Virtual box中Ubuntu碎片 ...

  5. jquery.string.js

    /** * jquery.string - Prototype string functions for jQuery * version: 1.1.0 * (c) 2008-2011 David E ...

  6. java位移运算符3 转

    https://www.cnblogs.com/winsker/p/6728672.html 移位运算符操作的对象就是二进制的位,可以单独用移位运算符来处理int型整数. 理解java移位运算符 运算 ...

  7. 【转】Mac 删除文件夹里所有的.svn文件

    转自: mac 删除文件夹里所有的.svn文件   想要把SVN專案作轉移或複製時 舊的「.svn」真的是很煩人的東西 最快的方式是用終端機輸入 sudo find /Users/justfly/Do ...

  8. FFT Cheetsheet

    参考资料 https://oi.men.ci/fft-notes/ 单位根(此类群均可) \(ω^0, ω^1, \dots, ω^{n-1}互不相同\) \(ω^k_n=ω^{2k}_{2n}\) ...

  9. 【C语言编程练习】新娘与新郎

    1. 题目要求 新郎A,B,C与新娘 X,Y,Z.有人不知道她们谁和谁结婚了,询问了6位新人中的三位,A说他将和X结婚,X说她的未婚夫是C,C说她会和Z结婚,一听就知道是全是假话,请编程找出谁和谁结婚 ...

  10. 20162329张旭升 2018-2019-2《网络对抗技术》第1周 Kali的安装

    目录 Kali的安装 设置与主机的文件交互 Kali的安装 1.创建虚拟机 2.选择安装语言 3.设置网络 4.设置分区 5.安装完成 设置与主机的文件交互 首先在vmware workstation ...