博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
mysql开发规范(优化)
阅读量:6816 次
发布时间:2019-06-26

本文共 1197 字,大约阅读时间需要 3 分钟。

规范

  1. 库名、表名、字段名必须使用小写字母, 并采用下划线分割, 禁止超过32个字符(整齐、易读)

  2. 临时库、表名须以tmp加日期为后缀;

  3. 使用Innodb存储引擎.【好处: 支持事务和行级锁】

  4. 字符集统一使用UTF8mb4【most bytes 4《支持Emoji和全部中文】;

  5. 表,字段增加注释,方便后期维护,枚举型标明说明文字.

  6. 控制单表字段数量,建议冷热数据分离,大字段分离,提升IO性能;

  7. 统一常用字段的含义与使用,比如很多表都会出现创建时间、更新时间、删除时间、软删除字段、状态等等,团队内约定好对应的字段、类型、默认值等等。

  8. 不使用视图、外键,而是通过代码多次实现 【视图/外键需要修改地方众多,可读性可迁移性较差】

  9. 单表数据量控制在5000w以内,超出要分库分表;

  10. 字段选择:

    • 字符串: 优先使用varchar,如果长度基本固定的列,如果该列恰好更新又特别频繁,适合char,大文本使用text;
    • 数字: 使用tinyint(1)来代替 enum和boolean
    • 时间: 推荐使用datetime;
      • datetime 和timestamp类型所占的存储空间不同,前者8个字节,后者4个字节,timestamp只能到2038-01-19 11:14:07;
      • timestamp类型随时间不同而不同.
  11. 索引:

    • 个数: 索引个数控制在5个以内, 索引在加快访问速度的同时,会增加维护负担,增大IO压力,索引占用空间是成倍增加的
    • 主键索引: 一般情况下优先考虑UUID,【考虑UUID和自增id的应用场景】
    • 在使用前使用explain看能否命中索引;
    • 组合索引要遵循最左原则: 例如index(‘c1’, ‘c2’, ‘c3’) where ‘c2’ = ‘aaa’ 不使用索引,where c2 = aaa and c3=sss 不能使用索引(如果第一个字段出现 范围符号的查找,那么将不会用到索引,如果是第二个或者第三个字段使用范围符号的查找,那么他会利用索引,利用的索引) 
    • 索引字段必须使用 NOT NULL + 默认值的形式,其他的不加NOT NULL对于性能提升影响不大;
  12. SQL语句

    • 杜绝直接 SELECT * 读取全部字段,列出要读取的字段;
    • 使用where,limit,offset等字段标明范围,尽量避免全表搜索;
    • 使用like模糊匹配,%尽量不要放首位,会导致搜索失效;

优化

  1. 大数据量获取全部尽量采用并行分批的方案去做;
  2. 分页优化: 尽量使用where条件 + limit 替换 offset + limit,
  3. SQL语句中IN包含的值不应超过200个,如果过多则分批;
  4. 读写分离;
  5. 为搜索字段建索引;
  6. 避免select *, 列出要读取的字段;

扩展

1. 

 

转载于:https://www.cnblogs.com/zhaowinter/p/10751367.html

你可能感兴趣的文章
资源文件加载(Pack URI 方案)
查看>>
步步为营:Asp.Net使用HttpWebRequest通知,抓取,采集
查看>>
求2维数组相邻元素的和的最大值
查看>>
大数据开发实战:离线大数据处理的主要技术--Hive,概念,SQL,Hive数据库
查看>>
VsCode使用之HTML 中 CSS Class 智能提示
查看>>
JMeter基础之一 一个简单的性能测试
查看>>
【转】性能测试工具 性能测试如何做?
查看>>
fullpage.js禁止滚动
查看>>
LoadRunner中响应时间与事物时间详解
查看>>
ZigZag Conversion
查看>>
Android 通过HTTPCLINET POST请求互联网数据
查看>>
Hadoop集群的配置(一)
查看>>
Kafka 学习笔记之 Consumer API
查看>>
教程-Close、Halt、terminate、ExitProcess的区别
查看>>
10款很好用的 jQuery 图片滚动插件
查看>>
teacher forcing
查看>>
Linux命令小记
查看>>
基于ROS和beaglebone的串口通信方式,使用键盘控制移动机器人
查看>>
android.view.WindowLeaked的解决办法
查看>>
存储过程的笔记
查看>>