一、基础规范

  1. 使用InnoDB存储引擎
    支持事务、行级锁、并发性能更好、CPU及内存缓存页优化使得资源利用率更高
  2. 推荐使用utf8mb4字符集
    无需转码,无乱码风险, 支持emoji表情以及部分不常见汉字
  3. 表、字段必须加注释
    方便他人理解字段意思,在后期维护中非常非常有用,不用去瞎猜这个字段是干嘛的。
  4. 不在数据库做计算
    禁止使用存储过程、视图、触发器、Event。
    在并发量大的情况下,这些功能很可能将数据库拖跨,业务逻辑放到服务层具备更好的扩展性,能够轻易实现“增机器就加性能”
  5. 禁止存储文件
    文件存储在文件系统,数据库里存URI
  6. 控制单表数据量

    单表记录控制在千万级

二、命名规范

  1. 库名、表名、字段名:小写,下划线风格

    非唯一索引名idxxxx,唯一索引名uniqxxx
  2. 表必须有主键,例如自增主键

    a)主键递增,数据行写入可以提高插入性能

    b)主键要选择较短的数据类型,Innodb引擎普通索引都会保存主键的值,较短的数据类型可以有效的减少索引的磁盘空间,提高索引的缓存效率

    c)保证实体的完整性,唯一性
  3. 不要使用外键,如果有外键约束,用应用程序控制

    外键会导致表与表之间耦合,update与delete操作都会涉及相关联的表,十分影响sql 的性能,甚至会造成死锁。高并发情况下容易造成数据库性能下降,大数据高并发业务场景数据库使用以性能优先

三、字段设计规范

  1. 把字段定义为NOT NULL并且提供默认值

    a)null的列使索引/索引统计/值比较都更加复杂,对MySQL来说更难优化

    b)null 这种类型MySQL内部需要进行特殊处理,增加数据库处理记录的复杂性;同等条件下,表中有较多空字段的时候,数据库的处理性能会降低很多

    c)null值需要更多的存储空间,无论是表还是索引中每行中的null的列都需要额外的空间来标识

    d)对null 的处理时候,只能采用is null或is not null,而不能采用=、in、<、<>、!=、not in这些操作符号。如:where name!=’zhangsan’,如果存在name为null值的记录,查询结果就不会包含name为null值的记录
  2. 不要使用TEXT、BLOB类型

    会浪费更多的磁盘和内存空间,非必要的大量的大字段查询会淘汰掉热数据,导致内存命中率急剧降低,影响数据库性能,如果必须要使用则独立出来一张表,用主键来对应,避免影响其它字段索引效率
  3. 不要使用小数存储货币

    建议使用整数,小数容易导致钱对不上
  4. 必须使用varchar存储手机号

    手机号会去做数学运算么?
  5. 为提高效率可以牺牲范式设计,冗余数据

    a)不是频繁修改的字段

    b)不是 varchar 超长字段,更不能是 text 字段

四、索引设计规范

  1. 禁止在更新十分频繁、区分度不高的属性上建立索引

    a)更新会变更B+树,更新频繁的字段建立索引会大大降低数据库性能

    b)“性别”这种区分度不大的属性,建立索引是没有什么意义的
  2. 建立组合索引,必须把区分度高的字段放在最左边

    因为使用单字段查询时会使用组合索引的左边字段而不使用右边的字段,如果 where a=? and b=? , a 列的几乎接近于唯一值,那么只需要单建 idx_a 索引即可
  3. 页面搜索严禁左模糊或者全模糊

    索引文件具有 B-Tree 的最左前缀匹配特性,如果左边的值未确定,那么无法使用此索引, 如果需要请走搜索引擎来解决

五、SQL使用规范

  1. 禁止使用SELECT *,只获取必要的字段,需要显示说明列属性

    a)消耗cpu,io,内存,带宽

    b)不能有效的利用覆盖索引

    c)使用SELECT *容易在增加或者删除字段后出现程序BUG, 不具有扩展性
  2. 使用INSERT INTO t_xxx VALUES(xxx),必须显示指定插入的列属性

    容易在增加或者删除字段后出现程序BUG
  3. 务必请使用“同类型”进行比较,否则可能全表扫面

    SELECT name FROM t_user WHERE phone=1888888888 会导致全表扫描.
  4. 禁止在WHERE条件的上使用函数或者计算

    解读:SELECT naem FROM tuser WHERE date(createdatatime)='2017-12-29' 会导致全表扫描

    推荐的写法是:SELECT name FROM tuser WHERE createdatatime>= '2017-12-29' and create_datatime < '2017-12-30'
  5. 禁止负向查询,以及%开头的模糊查询

    a)负向查询条件:NOT、!=、<>、!<、!>、NOT IN、NOT LIKE等,会导致全表扫描

    b)%开头的模糊查询,会导致全表扫描
  6. 不要大表使用JOIN查询,禁止大表使用子查询

    会产生临时表,消耗较多内存与CPU,极大影响数据库性能
  7. OR改写为IN()或者UNION

    原因很简单or不会走索引
  8. 简单的事务

    事务就像程序中的锁一样粒度尽可能要小
  9. 不要一次更新大量数据

    数据更新会对行或者表加锁,应该分为多次更新

MySQL优化之推荐使用规范的更多相关文章

  1. MySQL优化建议与使用规范

    适用场景:并发量大.数据量大的互联网业务;可以先阅读必须掌握的MySQL优化指南 一.基础规范 (1)必须使用InnoDB存储引擎 解读:支持事务.行级锁.并发性能更好.CPU及内存缓存页优化使得资源 ...

  2. MySQL优化聊两句

    原文地址:http://www.cnblogs.com/verrion/p/mysql_optimised.html MySQL优化聊两句 MySQL不多介绍,今天聊两句该如何优化以及从哪些方面入手, ...

  3. 单表60亿记录等大数据场景的MySQL优化和运维之道

    此文是根据杨尚刚在[QCON高可用架构群]中,针对MySQL在单表海量记录等场景下,业界广泛关注的MySQL问题的经验分享整理而成,转发请注明出处. 杨尚刚,美图公司数据库高级DBA,负责美图后端数据 ...

  4. 【转】单表60亿记录等大数据场景的MySQL优化和运维之道 | 高可用架构

    此文是根据杨尚刚在[QCON高可用架构群]中,针对MySQL在单表海量记录等场景下,业界广泛关注的MySQL问题的经验分享整理而成,转发请注明出处. 杨尚刚,美图公司数据库高级DBA,负责美图后端数据 ...

  5. [转载] 单表60亿记录等大数据场景的MySQL优化和运维之道 | 高可用架构

    原文: http://mp.weixin.qq.com/s?__biz=MzAwMDU1MTE1OQ==&mid=209406532&idx=1&sn=2e9b0cc02bdd ...

  6. 单表60亿记录等大数据场景的MySQL优化和运维之道 | 高可用架构

    015-08-09 杨尚刚 高可用架构 此文是根据杨尚刚在[QCON高可用架构群]中,针对MySQL在单表海量记录等场景下,业界广泛关注的MySQL问题的经验分享整理而成,转发请注明出处. 杨尚刚,美 ...

  7. MySQL数据库设计与开发规范

    目录 1. 规范背景与目的 2. 设计规范 2.1. 数据库设计 2.1.1. 库名 2.1.2. 表结构 2.1.3. 列数据类型优化 2.1.4. 索引设计 2.1.5. 分库分表.分区表 2.1 ...

  8. MySQL优化之路

    一.Mysql的存储原理 索引相关 本质 ​ 索引是帮助MySQL高效获取数据的排好序的数据结构 ​ 建索引,提高数据检索的效率,降低数据库的IO成本: 通过索引列对数据进行排序,降低数据排序的成本, ...

  9. mysql优化大全(转自别人 )

    文章出处:https://blog.csdn.net/weixin_38112233/article/details/79054661 数据库优化 sql语句优化 索引优化 加缓存 读写分离 分区 分 ...

随机推荐

  1. Outlook IMAP 修改PST文件存储路径

    IMAP类型的账户修改PST文件位置方法: 对于IMAP类型账户的PST文件,既没有“修改文件夹”的选项,也无法按OFFICE官方操作指南中的操作.因为每次Outlook只要检测到默认路径下的PST文 ...

  2. vs2017更新出错:The entire Box execution exiting with result code: 0x0

    在将vs2017 15.7.4更新至15.9.5出现“The entire Box execution exiting with result code: 0x0”错误,也就是文件解压下载开始安装后, ...

  3. react-native中显示手机本地图片/视频

    已知文件路径'/data/user/0/com.ycdj/files/media/218787782/efa1d12f22d2/1235.jpg' 只需在路径前面拼上file:///即可,如: < ...

  4. 浅谈Java语言中try{}catch{}和finally{}的执行顺序问题

    浅谈Java语言中try{}catch{}和finally{}的执行顺序问题 2019-04-06  PM  13:41:46  1. 不管有没有出现异常,finally块中代码都会执行: 2. 当t ...

  5. 2018-2019-2 20165319 《网络对抗技术》 Exp5:MSF基础应用

    实验内容 metasploit中有六个模块分别是 渗透攻击模块(Exploit Modules) 辅助模块(Auxiliary Modules 攻击载荷(Payload Modules) 空字段模块( ...

  6. maya cmds pymel 'ESC' 退出 while, for 循环

    maya cmds pymel 'ESC' 退出 while, for 循环 import maya.cmds as cmds cmds.progressWindow(isInterruptable= ...

  7. PCA:利用PCA(四个主成分的贡献率就才达100%)降维提高测试集辛烷值含量预测准确度并《测试集辛烷值含量预测结果对比》—Jason niu

    load spectra; temp = randperm(size(NIR, 1)); P_train = NIR(temp(1:50),:); T_train = octane(temp(1:50 ...

  8. [R]R包版本更迭【持续更新】

    由于R版本更迭,网上或旧的教材上的包可能没有在维护,或者被其他包替代. 做一个表记录碰到的一些替代方案.个人向,非完整指南. * mvpart 2014年之后不再更新,R 3.0版本后无法安装, 提示 ...

  9. Pandas 1 表格数据类型DataFrame

    # -*- encoding:utf-8 -*- # Copyright (c) 2015 Shiye Inc. # All rights reserved. # # Author: ldq < ...

  10. Zathura: 轻巧好用的 PDF 查看器]

    [Zathura: 轻巧好用的 PDF 查看器](https://linuxtoy.org/archives/zathura.html) 这个文件很轻巧,且支持VIM方式的 快捷键