IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 大数据 -> Mysql军规(编写规范) -> 正文阅读

[大数据]Mysql军规(编写规范)

Mysql军规(编写规范)



前言

以下是使用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


仰天大笑出门去,我辈岂是蓬蒿人

  大数据 最新文章
实现Kafka至少消费一次
亚马逊云科技:还在苦于ETL?Zero ETL的时代
初探MapReduce
【SpringBoot框架篇】32.基于注解+redis实现
Elasticsearch:如何减少 Elasticsearch 集
Go redis操作
Redis面试题
专题五 Redis高并发场景
基于GBase8s和Calcite的多数据源查询
Redis——底层数据结构原理
上一篇文章      下一篇文章      查看所有文章
加:2022-11-05 00:34:29  更:2022-11-05 00:36:55 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年5日历 -2025/5/1 18:59:06-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码