这个是某公司技术基础建设的一部分,本次提出秉着分享的精神跟大家一起探讨探讨,欢迎互相切磋~
这个文章是为了规范公司的数据库使用的,如果公司有原来使用的规范可以做下对比。这个规范适合中小型公司,数据量不是特别大的。设计的单表容量在千万级。
数据库使用 MYSQL ,版本 5.7+
数据库使用主要属性类型,数字用 int ,字符用 char ,比较多的字符用 text 或者 verchar, 根据实际情况,能用char的,尽量不要使用 verchar 。需要数据库控制时间的用 timestamp 给默认值即可。不需要数据库控制时间的 使用 char ,用程序控制即可。
涉及到金钱的使用 decimal(40,20) 统一用这个,可以兼容区块链相关钱币。
以上 属性类型基本可以满足 90% 以上的业务场景,需要严格遵守。
主键自增ID自带索引。
禁止使用 tinyint ,bigint 等数字类型。可能有人要给主键用bigint 但要考虑到,int类型就有上亿条数据量了,是否能达到?自己写个程序往数据库里插入几百万条数据试试,看怎样操作就明白了。
禁止使用其他时间格式,比如date 等。涉及到时间的可以直接使用char