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字段上建立索引时,必须指定索引长度,没必要对全字段建索引
  • 建立联合索引时要根据左前缀原则避免冗余,其次要把区分度高的字段放在前面
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值