数据库设计规范

Mysql数据库设计规范

  1. 数据库名、表名和字段名使用小写字母和阿拉伯数字,单词不能以数字开头,所有单词不使用复数名词,单词间用下划线(_)连接,禁用数据库保留字作为表中的字段名,如:desc,name,time,datetime,password等。
  2. 主键命名为id,若无主键必须添加id自增字段,数据类型为bigint(20) unsigned,其它字段如created_at,expired_at,updated_at根据需求选用,数据类型为int(10) unsigned,保存UTC时间。
  3. 如果主键在业务上需要暴露,则需要添加uuid字段,类型为char(36),必须建唯一索引,代替id暴露在外,不允许自增id暴露在外。
  4. 外键命名规则为{表名_id},例如关联表foo的id字段,则字段名为foo_id,禁止使用mysql的外键关联声明foreign key,关联关系请在业务层处理。
  5. 任何时候不使用软删除代替物理删除,如果某张表A需要物理删除记录,先SELECT后编码(json、序列化等)保存到指定备份表,再DELETE。
  6. 保存时间值的字段只允许使用int(10) unsigned类型,IP保存为bigint(20),手机号码保存为char(11),保存手机最好同时添加手机地域字段(+86等)。
  7. 保存bool值的字段使用(is_)作为字段前缀,0代表false,1代表true,数据类型为tinyint(1) unsigned。
  8. 除了id,uuid,created_at,expired_at,updated_at等约定的字段可以不用添加注释外,要有表注释和字段注释。
  9. 每个字段属性都为NOT NULL,使用默认0值或空字符串值填充代表null。
  10. enum使用tinyint(4)代替,float、double使用decimal代替。
  11. char,varchar字段,保存表情要用utf8mb4编码,用户名之类的字段不区分大小写,定长字符串使用char(例如uuid,哈希值,手机号码等)。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值