Mysql军规
2022/1/19 2:13:07
本文主要是介绍Mysql军规,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
读选比无限接近1,一次IO不要查太多数据,一次IO更新一条数据。 读选比无限接近1,一次IO不要查太多数据,一次IO更新一条数据。 读选比无限接近1,一次IO不要查太多数据,一次IO更新一条数据。 【军规】必须使用UTF8字符集,如果表中涉及用户输入信息,使用utf8mb4字符集 【军规】禁止使用存储过程、视图、触发器 【军规】只允许使用内网域名,而不是ip连接数据库 【军规】禁止使用 INSERT ... ON DUPLICATE KEY UPDATE 【军规】只允许通过主键执行DELETE与UPDATE操作,不能通过其它字段更新与删除 【军规】禁止使用SELECT *,只获取必要的字段,需要显示说明列属性 【军规】禁止使用三个表以上的关联查询 【军规】禁止一次性查询大量结果。一次select的结果如果超过100行数据,请认真评估实现的合理性,确认合理的话采取分批查询 【军规】禁止使用mysql分区表 【军规】禁止使用负向查询NOT、!=、<>、!<、!>、NOT IN、NOT LIKE等,会导致全表扫描 【军规】禁止将业务逻辑写在sql脚本中 【军规】MySQL是IO密集型,尽量不要在sql中使用cpu运算类功能 【军规】默认使用主库,业务对数据一致性要求不高、且纯查询场景才走读库 【军规】所有表必须使用Innodb存储引擎 【军规】所有表和字段都需要添加注释 【军规】尽量控制单表数据量的大小,建议控制在500万以内 【军规】禁止在数据库中存储图片,文件等大的二进制数据 【军规】尽量做到冷热数据分离,减小表的宽度 【军规】优先选择符合存储需要的最小的数据类型 【军规】避免使用ENUM类型 【军规】使用TIMESTAMP(4个字节)或DATETIME类型(8个字节)存储时间 【军规】同财务相关的金额类数据必须使用decimal类型 【军规】限制每张表上的索引数量,建议单张表索引不超过5个 【军规】尽可能把所有列定义为NOT NULL 【军规】避免建立冗余索引和重复索引 【军规】禁止使用SELECT * 必须使用SELECT <字段列表> 查询 【军规】禁止使用不含字段列表的INSERT语句 【军规】避免使用子查询,可以把子查询优化为join操作 【军规】SQL中出现order by,必须通过索引实现,且需要通过代码review 【军规】避免使用insert ignore,insert ignore在表字段超长的时候会被自动截取,不会报data too long for column 【军规】变更索引的时候,只能先建索引,再删索引 【军规】提交sql工单的时候备注上时间,没有备注执行时间的默认是晚上20:00之后执行 【军规】禁止使用delete 引入is_delete字段实现。比如有个工员表employee(id, name, is_deleted),name唯一,唯一索引还是只用(name)字段,不要包括is_deleted 创建操作:先判断name是否存在 select * from employee where name = 'xxx' 若记录不存在,则直接新增记录,并且置is_deleted = 0 若记录存在,且is_deleted = 0,提示记录已存在,创建失败 若记录存在,且is_deleted = 1,则做更新操作,用当前请求的值覆盖记录,并且置is_deleted = 0 删除操作,直接更新is_deleted = 1
这篇关于Mysql军规的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-04-26MySQL查出时间比实际晚8小时的解决方案
- 2024-04-01JPA不识别MySQL的枚举类型
- 2024-03-30mysql数据库表卡死解决方法
- 2024-03-15MySQL多数据源笔记5-ShardingJDBC实战
- 2024-03-11natural join mysql
- 2024-03-11关于VS2017,VS2015 中利用 EF使用Mysql 不显示数据源问题解决方案
- 2024-02-26mysql 阿里云xb后缀备份文件恢复-icode9专业技术文章分享
- 2024-02-22docker mysql 5.7
- 2024-02-18从 20 多套 MySQL 到 1 套 TiDB丨骏伯网络综合运营管理平台应用实践
- 2024-02-07mysql 外键索引入门介绍,为什么工作中很少有人使用?