MySQL表结构设计规范

一、表设计

1. 命名规范

  • 表名由小写英文字母下划线组成
  • 表必须填写描述信息
  • 表名中的英文单词应该使用单数形式
  • 临时表以 tmp 为前缀,以日期为后缀
  • 备份表以 bak 为前缀,以日期为后缀
  • 使用hash、md5 进行散表,表名后缀使用16进制

2. 设计规范

  • 必须定义主键,一般默认为id,整型自增
  • 主键不允许修改,一般采用业务无关字段
  • 表必须包含 gmt_creategmt_modified 字段记录创建时间和修改时间
  • 禁止使用外键
  • 慎用触发器和存储过程。将业务逻辑放到应用层更合适
  • 单条记录禁止超过 8kb
  • 单表列数一般不超过50
  • 单表数据量建议控制在500万行一下、2GB内

3. 字段设计

  • 在满足数据存储和扩展需要的前提下,尽量使用更小的数据类型
  • 在表达是否概念时,使用 is_xxx 形式命
  • 建立索引的字段必须定义为 not null,并设置 default
  • 存储小数尽量使用decimal,避免丢失精度
  • 避免使用小数存储金额,一般转换为最小单位的整数倍存储
  • 避免使用 text、blob 存储大文本、文件、图片,应使用文件系统存储
  • varchar 要根据业务实际需要进行长度控制。虽然在存储层面根据实际长度存储,但在内存分配时是根据指定长度,不合理的长度设计会导致内存分配不合理

4. 索引设计

  • 选择区分度高的字段作为索引项
  • 避免在频繁更新的字段上建索引
  • 单表索引建议控制在5个以内
  • 在varchar字段上建立索引时,必须指定索引长度,没必要对全字段建索引
  • 建立联合索引时要根据左前缀原则避免冗余,其次要把区分度高的字段放在前面

你可能感兴趣的:(MySQL,mysql,设计规范,数据库)