1.存储引擎选择
OLTP(on-line transaction processing)联机事务处理类型的应用选择innodb
OLAP(On-Line Analytical Processing)联机分析处理选择Myisam
2.字符集选择
UTF8字符集(世界通用,无需转码)
3.命名规范
库名、表名、字段名:小写,下划线风格,不超过32个字符
4.表结构设计
表必须设置有主键
- 主键递增,数据行写入可以提高插入性能,可以避免page分裂,减少表碎片提升空间和内存的使用
- 主键要选择较短的数据类型, Innodb引擎普通索引都会保存主键的值,较短的数据类型可以有效的减少索引的磁盘空间,提高索引的缓存效率
- 无主键的表删除,在row模式的主从架构,会导致备库夯住
单实例表数目不大于500
单表列数不大于40
尽量不使用外键
5.字段设计
尽量将字段定于为NOT NULL,并且提供默认值。
- null的列使索引/索引统计/值比较都更加复杂,对MySQL来说更难优化
- null 这种类型MySQL内部需要进行特殊处理,增加数据库处理记录的复杂性;同等条件下,表中有较多空字段的时候,数据库的处理性能会降低很多
- null值需要更多的存储空,无论是表还是索引中每行中的null的列都需要额外的空间来标识
- 对null 的处理时候,只能采用is null或is not null,而不能采用=、in、<、<>、!=、not in这些操作符号。如:where name!=’shenjian’,如果存在name为null值的记录,查询结果就不会包含name为null值的记录
尽量不使用test 和blob 大文件,图像在外部存储
精确存储小数使用decimal