MySQL开发设计规范

摘要:
建议在时间范围小于2037时使用TIMESTAMP,因为TIMESTAMP占用的空间较小。6.使用current_ timestamp()函数将create添加到关键业务数据表_ Time和update_ Time字段,以定义默认值,以便于后续数据分析和问题跟踪。示例:create_ timetimestamp NOTNULLDEFAULTCURRENT_ TIMESTAMPCOMMENT“创建时间”,update_ timetimetamp NOTNulLDEFAULT“0000-00-0000:00”ONUPDATECURRENT_ TIMETAMPCOMMEnt“修改时间”7。精确浮点数的存储必须使用DECIMAL来替换FLOAT和DOUBLE8。所有字段都显示并定义为NOT NULL,请勿使用DEFAULTNULL,并指定一个DEFAULT值×AaavarcharDEFAULTNULL√ aaavarcharNOTNULLDEFAULT“”√ bbbintNOTNULLDEFAULT-19.char,Varchar具有适当的长度,并且在可预见的范围内应尽可能清楚varhcar中的数字不是字节而是字符,因此这里可以保存10个汉字或字母。

1.库命名规则:dbname_suffix,分为_dev/_test/_pre/_mertest/_perf/_prod六个环境

2.适度反范式设计,冗余表字段数据减少JOIN关联提高访问效率

3.普通索引命名:idx_字段名,联合索引命名:idx_字段名1_字段名2…,唯一索引命名:uq_字段名

4.表和字段必须加上(中文)注释

5.存储时间类型datetime/timestamp/date等,不使用char/varchar。【建议】建议当时间范围小于2037年使用TIMESTAMP类型,因为 TIMESTAMP占用空间更小

6.关键业务数据表,增加create_time和update_time字段,使用current_timestamp()函数定义默认值,方便后期数据分析和问题追溯

示例:

create_timetimestamp NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',

update_timetimestamp NOT NULL DEFAULT '0000-00-00 00:00:00' ON UPDATE CURRENT_TIMESTAMP COMMENT '修改时间'

7.存储精确浮点数必须使用 DECIMAL 替代 FLOAT 和 DOUBLE

8.所有字段均显示定义为NOT NULL,不使用 DEFAULT NULL 并指定DEFAULT值

× aaavarchar(32) DEFAULT NULL

√ aaavarchar(32) NOT NULL DEFAULT ''

√ bbbint NOT NULL DEFAULT -1

9.char ,Varchar 长度适当,可预见范围内尽量小

说明:varhcar(10) 中的数字不是字节而是字符,那么此处能存下10个汉字或字母。**

× `aaa` varchar(2000) NOT NULL DEFAULT ''

10.单表字段数量控制在50个以内,尽可能不使用TEXT、BLOB 类型,将过大字段拆分到其他表中

11.支持创建新表和添加新字段,禁止drop和rename表名和字段名(支持应用上灰度发布)

12.UPDATE、DELETE 语句需要根据 WHERE 条件添加索引

13.对长度过长的 VARCHAR 字段建立索引时, 添加 crc32 或者 MD5 Hash 字段, 对 Hash 字段建立索引

14.禁止在更新频繁、区分度不高的字段上建立索引

15.JOIN字段要创建索引

16.单个索引字段数不超过5,最好使用唯一性好的索引,单表索引数量不超过5

17.ORDER BY,GROUP BY,DISTINCT 的字段需要添加在索引的后面,否则会很消耗io、cpu计算资源

18.SELECT 语句只输出需要的字段,禁止SELECT *

19.SELECT、INSERT 语句必须显式的指明字段名称,不使用 SELECT *,不使用 INSERT INTO table()

20.写密集场景INSERT 语句使用 batch 提交(INSERT INTO table VALUES(),(),()……) ,values 的个数不应过多,控制在1000个以内

21.避免大表与大表之间的JOIN,考虑让小表去驱动大表JOIN

22.关于分页优化,两种分页查询的正确姿势:

SELECT * FROM table WHERE TIME<last_TIME ORDER BY TIME DESC LIMIT 10

SELECT * FROM table inner JOIN(SELECT id FROM table ORDER BY TIME LIMIT 10000,10) as t USING(id)

23.WHERE语句中使用IN代替OR ,但IN的值不超过1000,或改写成JOIN性能会更好

24.WHERE 条件中的非等值条件(IN、BETWEEN、<、<=、>、>=)会导致后面的条件使用不了索引

25.WHERE 条件中字段禁止运算禁止使用函数`× where id + 1 = 100

√ where id = 100 -1

× where unix_timestamp('time') = 1366169490

√ where time = FROM_UNIXTIME(1366169490) `

26.WHERE中禁止使用%前缀模糊查询,例如 LIKE “%abc”,会导致全表扫描

免责声明:文章转载自《MySQL开发设计规范》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇抓取js动态生成的数据案列laravel Event执行顺序下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

转:Linux 编译安装 Mysql5.7

http://broqiang.com/2017/04/18/Mysql-Install-5.7.18-Linux-Compile/ 原文 Linux 编译安装 Mysql5.7 Ubuntu 下快速安装直接 apt 方式即可, 一般的开发环境也足够了 个人比较喜欢新版本,一般有新版本就会尝试一下 此文档适用于 Ubuntu 16.10 和 CentOS...

mysql_【MySQL】常见的mysql 进程state

Analyzing 线程是对MyISAM 表的统计信息做分析(例如, ANALYZE TABLE )。 checking permissions 线程是检查服务器是否具有所需的权限来执行该语句。 Checking table 线程正在执行表检查操作。 cleaning up 线程处理一个命令,并正准备以释放内存和重置某些状态变量。 closing tabl...

【MySQL笔记】mysql来源安装/配置步骤和支持中国gbk/gb2312编码配置

不久的学习笔记。分享。我想有很大的帮助谁刚开始学习其他人的 备注:该票据于mysql-5.1.73版本号例如 1. mysql源代码编译/安装步骤 1) 官网下载mysql源代码并解压 2) cd至源代码文件夹。运行 ./configure --prefix=/home/slvher/tools/mysql-5.1.73 --with-charset=...

shell一键安装zabbix

shell     一键部署zabbix服务 (注:脚本当中要注意标点符号的中英文切换) !/bin/bash #关闭防火墙,关闭selinux systemctl stop firewalld setenforce 0 #配置yum源 rpm -ivh http://repo.zabbix.com/zabbix/4.0/rhel/7/x86_64/zab...

Mariadb 修改 Root 密码

默认情况下,新安装的 mariadb 的密码为空,在shell终端直接输入 mysql 就能登陆数据库。 如果是刚安装第一次使用,请使用 mysql_secure_installation 命令初始化。 # mysql_secure_installation NOTE: RUNNING ALL PARTS OF THIS SCRIPT IS RECOMM...

Docker mysql主从配置

一:Mysql基于Docker的主从复制搭建 1:安装docker,安装步骤可见我之前的文章:Docker-常用基建的安装与部署 docker ps 命令查询当前的容器状态,这就是我们最后要达到的效果。 2:首先拉取mysql官方镜像 bash> docker pull mysql:5.7 演示环境是在同一台服务器上部署。因为docker创建容器时...