获取中...

-

Just a minute...

MySQL数据库开发规范

  1. 所有的数据库对象名称必须使用小写字母并用下划线分割(MySQL大小敏感,见名知意,最好不超过32字符)
  2. 所有的数据库对象名称禁止使用MySQL保留关键字(如 desc、range、match、delayed 等,请参考 MySQL 官方保留字http://dev.mysql.com/doc/refman/5.7/en/keywords.html)
  3. 临时库表必须以tmp为前缀并以日期为后缀(tmp_)
  4. 备份库和库,必须以bak为前缀,日期为后缀(bak_)
  5. 所有存储相同数据的列名和列类型必须一致。(在多个表中的字段如user_id)
  6. mysql5.5之前默认的存储的引擎是myisam,没有特殊要求,所有的表必须使用innodb(支持失误,行级锁,高并发下性能更好,对多核,大内存,ssd等硬件支持更好)
  7. 数据库和表的字符集统一使用utf8【要统一,避免由于字符集转换产生的乱码】。汉字utf8下暂3个字节
  8. 所有表和字段都要添加注释COMMENT,从一开始就进行数据字典的维护
  9. 尽量控制单表数据量的大小在500w以内,超过500w可以使用历史数据归档,分库分表来实现(500万行并不是MySQL数据库的限制。过大对于修改表结构,备份,恢复都会有很大问题。MySQL没有对存储有限制,取决于存储设置和文件系统)。
  10. 谨慎使用mysql分区表(分区表在物理上表现为多个文件,在逻辑上表现为一个表)。
  11. 谨慎选择分区键,跨分区查询效率可能更低
  12. 建议使用物理分表的方式管理大数据
  13. 尽量做到冷热数据分离,减小表的宽度(mysql限制最多存储4096列,行数没有限制,但是每一行的字节总数不能超过65535)【列限制好处:减少磁盘io,保证热数据的内存缓存命中率,避免读入无用的冷数据】
  14. 禁止在表中建立预留字段(无法确认存储的数据类型,对预留字段类型进行修改,会对表进行锁定)
  15. 禁止在数据中存储图片,文件二进制数据(使用文件服务器)
  16. 禁止在线上做数据库压力测试
  17. 禁止从开发环境,测试环境直接连生产环境数据库
  18. 限制每张表上的索引数量,建议单表索引不超过5个(索引会增加查询效率,但是会降低插入和更新的速度)
  19. 避免建立冗余索引和重复索引(冗余:index(a,b,c) index(a,b) index(a))
  20. 禁止给表中的每一列都建立单独的索引
  21. 每个innodb表必须有一个主键,选择自增id(不能使用更新频繁的列作为主键,不适用UUID,MD5,HASH,字符串列作为主键),
  22. 区分度最高的列放在联合索引的最左侧
  23. 尽量把字段长度小的列放在联合索引的最左侧
  24. 尽量避免使用外键(禁止使用物理外键,使用逻辑外键)
  25. 优先选择符合存储需要的最小数据类型
  26. 优先使用无符号的整形来存储
  27. 优先选择存储最小的数据类型(varchar(N),N代表的是字符数,而不是字节数,N代表能存储多少个汉字)
  28. 避免使用Text或是Blob类型
  29. 避免使用ENUM数据类型(修改ENUM值需要使用ALTER语句,ENUM类型的ORDER BY操作效率低,需要额外操作,禁止使用书值作为ENUM的枚举值
  30. 尽量把所有的字段定义为NOT NULL(索引NULL需要额外的空间来保存,所以需要暂用更多的内存,进行比较和计算要对NULL值做特别的处理)
  31. 使用timestamp或datetime类型来存储时间
  32. 同财务相关的金额数据,采用decimal类型(不丢失精度,禁止使用 float 和 double)
  33. 避免使用双%号和like,搜索严禁左模糊或者全模糊(如果需要请走搜索引擎来解决。索引文件具有 B-Tree 的最左前缀匹配特性,如果左边的值未确定,那么无法使用此索)
  34. 建议使用预编译语句进行数据库操作
  35. 禁止跨库查询(为数据迁移和分库分表留出余地,降低耦合度,降低风险)
  36. 禁止select * 查询(消耗更多的cpu和io及网络带宽资源,无法使用覆盖索引)
  37. 禁止使用不含字段列表的insert语句(不允许insert into t values(‘a’,‘b’,‘c’)不允许)
  38. in 操作能避免则避免,若实在避免不了,需要仔细评估 in 后边的集合元素数量,控制在 1000 个之内
  39. 禁止使用order by rand()进行随机排序
  40. 禁止where从句中对列进行函数转换和计算(例如:where date(createtime)=‘20160901’ 会无法使用createtime列上索引。改成 where createtime>=’20160901’ and createtime <’20160902’)
  41. 尽量使用 union all 代替 union
  42. 拆分复杂的大SQL为多个小SQL( MySQL一个SQL只能使用一个CPU进行计算)
  43. 尽量避免使用子查询,可以把子查询优化为join操作(子查询的结果集无法使用索引,子查询会产生临时表操作,如果子查询数据量大会影响效率,消耗过多的CPU及IO资源)
  44. 超过100万行的批量写操作,要分批多次进行操作(大批量操作可能会造成严重的主从延迟,binlog日志为row格式会产生大量的日志,避免产生大事务操作)
  45. 对于大表使用pt—online-schema-change修改表结构(避免大表修改产生的主从延迟,避免在对表字段进行修改时进行锁表)
  46. 对于程序连接数据库账号,遵循权限最小原则
  47. 超过三个表禁止 join。(需要 join 的字段,数据类型必须绝对一致;多表关联查询时,保证被关联的字段需要有索引。即使双表 join 也要注意表索引、SQL 性能。)
  48. 在varchar字段上建立索引时,必须指定索引长度,没必要对全字段建立索引,根据实际文本区分度决定索引长度即可。
  49. SQL 性能优化的目标:至少要达到 range 级别,要求是 ref 级别,如果可以是 consts最好。
  50. 使用 ISNULL()来判断是否为 NULL 值。
  51. 禁止物理删除(即直接删除),只做逻辑删除,用deleteFlag做逻辑删除,如果删除,则为1,不删除则为0
  52. 如果有 order by 的场景,请注意利用索引的有序性。order by 最后的字段是组合,索引的一部分,并且放在索引组合顺序的最后,避免出现 file_sort 的情况,影响查询性能。
  53. 在代码中写分页查询逻辑时,若 count 为 0 应直接返回,避免执行后面的分页语句。
相关文章
评论
分享
  • Redis

    Redis介绍Redis 是完全开源免费的,遵守BSD协议,是一个高性能的key-value数据库。Redis 与其他 key - value 缓存产品有以下三个特点: Redis支持数据的持久化,可以将内存中的数据保存在磁盘中,重...

    Redis
  • MySQL

    数据库基础知识数据库的定义数据库:物理操作文件系统或其他形式文件类型的集合;实例:MySQL 数据库由后台线程以及一个共享内存区组成;在 MySQL 中,实例和数据库往往都是一一对应的,而我们也无法直接操作数据库,而是要通过数据库实例...

    MySQL
  • System-Security

    认证 认证(Authentication) 系统如何正确分辨出操作用户的真实身份? 通信信道上的认证:你和我建立通信连接之前,要先证明你是谁。在网络传输(Network)场景中的典型是基于 SSL/TLS 传输安全层的认证。 通信...

    System-Security
  • OAuth2授权码模式第三方应用先要到授权服务器上进行注册,然后从授权服务器中获取 ClientID 和 ClientSecret,以便能够顺利完成如下授权过程: 第三方应用将资源所有者(用户)导向授权服务器的授权页面,并向授权服务...

  • Java虚拟机

    JVM内存结构 VS Java内存模型 VS Java对象模型JVM内存结构Java代码是要运行在虚拟机上的,而虚拟机在执行Java程序的过程中会把所管理的内存划分为若干个不同的数据区域,这些区域都有各自的用途,其中有些区域随着虚拟机...

    Java虚拟机
  • Computer-Network

    TCPTCP(Transmission Control Protocol 传输控制协议)是一种面向连接的、可靠的、基于字节流的传输层通信协议。TCP通过校验和、序列号、确认应答、重发控制、连接管理以及窗口控制等机制实现可靠性传输。 T...

    Computer-Network
  • Java并发

    什么是线程安全,怎么保证线程安全?线程安全可以简单理解为一个方法或者一个实例可以在多线程环境中使用而不会出现问题 如何保证线程安全 JAVA 线程状态转换图示线程共包括以下5种状态。 新建状态(New) : 线程对象...

    Java并发
  • DataStructures-Algorithms

    动态规划动态规划过程是:每次决策依赖于当前状态,又随即引起状态的转移。一个决策序列就是在变化的状态中产生出来的,所以,这种多阶段最优化决策解决问题的过程就称为动态规划。 背包问题总结背包问题 (Knapsack problem x )...

    DataStructures-Algorithms
  • Design-Patterns

    设计模式主要分三个类型:创建型、结构型和行为型。创建型 Singleton,单例模式:保证一个类只有一个实例,并提供一个访问它的全局访问点 Abstract Factory,抽象工厂:提供一个创建一系列相关或相互依赖对象的接口,而...

    Design-Patterns
  • MyBatis

    MyBatis介绍在介绍MyBatis之前先简单了解几个概念:ORM,JPA。 ORMORM(Object-Relationship-Mapping):是对象关系映射的意思,它是一种思想,是指将数据库中的每一行数据用对象的形式表现出来...

    MyBatis
Please check the parameter of comment in config.yml of hexo-theme-Annie!