数据库规范

这里主要针对mysql数据库,其他数据库也可以借鉴

1、统一使用表命名规范

表名规范:分层+项目名缩写+实体名(小写)【+下划线+实体名+rel】

例子

表名:bc_user

分层:

  • 基础服务:b
  • 综合服务:s
  • webapp服务:a

表的种类:

  • 映射实体的表:前缀_实体名(多个单词用下划线隔开)
  • 关系表:前缀*_实体名1_实体名2_后缀(多个单词用下划线隔开)*

2、统一使用Innodb引擎

3、【推荐】表名不要关联其他表名的信息

表名含义项目范围独立

索引

1、业务上具有唯一特性的字段,即使是组合字段,必须使用唯一索引。

如果没有添加唯一索引,即使在应用层做了非常完善的校验和验证,也无法避免脏数据的产生。

2、唯一索引命名:uk_字段名 普通索引命名:idx_字段名

3、禁止对text定义索引

如果有对这类字段搜索的需求,可以通过全文索引方法来实现功能。

4、【推荐】varchar定义索引长度。长度统一10的倍数,不超过50;

一般有搜索的话,用户也不会输入太多字

字段

1、主键禁止使用自增。

不同库同步数据的时候,会出问题。

2、字段全部禁止为空。

为空的话,很容易在使用的时候出现npe异常

3、禁止使用外键,只能在概念和应用层次使用外键

影响插入性能

4、禁止使用枚举、集合类型
5、禁止在数据库使用blog存文件。

数据库只存相对的url路径

6、类型使用规范

  • 布尔:bit
  • 时间(精确到天):date
  • 时间(精确到秒):datetime
  • 浮点:deciaml
  • 字符串(长度小于10或者长度大于10但是长度相同):char
  • 字符串(长度为10~5000,长度不等):varchar
  • 字符串(富文本):text

7、必有字段

  • 主键
  • 创建时间
  • 修改时间
  • 假删状态

8、【推荐】可以审核添加冗余数据,这样可以快速查询数据。

冗余类型:
+ 技术器、计分器等统计数据
+ 一旦成功不会修改的数据

9、【推荐】字段顺序:自描述-》关联其他表的描述-》功能性-》必有字段

注释

1、表名或者字段注释的格式:直译【(补充说明)】

2、禁止带“表”、“数据”等多余的字眼

3、如果类型字段,有变更,同步注释

sql

1、禁止使用select *

数据库查看执行时间性能没有影响。但是返回的数据量会变大,对网络开销有影响,最终还是影响性能,而且会影响数据库的二进制日志

2、使用select count(*)

select count(name)不记录null的行数,而且官方澄清count(*)不影响性能

3、使用sum函数时,必须使用IFNULL(sum(),0)

如果sum函数没有查询结果返回null,容易出npe

4、禁止出现or。可以使用in或者unit all来替换

5、order by的场景,创建索引时order by后面的字段也必须是组合索引的一部分,并且放在索引顺序的最后,避免file_sort

6、创建组合索引时,区分度最高的放在最左边

where a=? and b=? 如果a几乎接近唯一,那么只要建idx_a即可。

7、【推荐】禁止更新表的所有字段,必须制定更新的字段