一、表设计
1. 命名规范
- 表名由小写英文字母和下划线组成
- 表必须填写描述信息
- 表名中的英文单词应该使用单数形式
- 临时表以 tmp 为前缀,以日期为后缀
- 备份表以 bak 为前缀,以日期为后缀
- 使用hash、md5 进行散表,表名后缀使用16进制
2. 设计规范
- 必须定义主键,一般默认为id,整型自增
- 主键不允许修改,一般采用业务无关字段
- 表必须包含 gmt_create 和 gmt_modified 字段记录创建时间和修改时间
- 禁止使用外键
- 慎用触发器和存储过程。将业务逻辑放到应用层更合适
- 单条记录禁止超过 8kb
- 单表列数一般不超过50
- 单表数据量建议控制在500万行一下、2GB内
3. 字段设计
- 在满足数据存储和扩展需要的前提下,尽量使用更小的数据类型
- 在表达是否概念时,使用 is_xxx 形式命名
- 建立索引的字段必须定义为 not null,并设置 default
- 存储小数尽量使用decimal,避免丢失精度
- 避免使用小数存储金额,一般转换为最小单位的整数倍存储
- 避免使用 text、blob 存储大文本、文件、图片,应使用文件系统存储
- varchar 要根据业务实际需要进行长度控制。虽然在存储层面根据实际长度存储,但在内存分配时是根据指定长度,不合理的长度设计会导致内存分配不合理
4. 索引设计
- 选择区分度高的字段作为索引项
- 避免在频繁更新的字段上建索引
- 单表索引建议控制在5个以内
- 在varchar字段上建立索引时,必须指定索引长度,没必要对全字段建索引
- 建立联合索引时要根据左前缀原则避免冗余,其次要把区分度高的字段放在前面