MySQL建表规约
来源:互联网 发布:oracle sql case when 编辑:程序博客网 时间:2024/06/09 15:27
前言
MySQL建表规约
正文
1. 【强制】表达是与否概念的字段,必须使用 is_xxx 的方式命名,数据类型是 unsigned tinyint
(1 表示是, 0 表示否) ,此规则同样适用于 odps 建表。
说明: 任何字段如果为非负数,必须是 unsigned。
2. 【强制】表名、字段名必须使用小写字母或数字; 禁止出现数字开头,禁止两个下划线中间只
出现数字。数据库字段名的修改代价很大,因为无法进行预发布,所以字段名称需要慎重考虑。
正例: getter_admin, task_config, level3_name
反例: GetterAdmin, taskConfig, level_3_name
3. 【强制】表名不使用复数名词。
说明: 表名应该仅仅表示表里面的实体内容,不应该表示实体数量,对应于 DO 类名也是单数
形式,符合表达习惯。
4. 【强制】禁用保留字,如 desc、 range、 match、 delayed 等, 请参考 MySQL 官方保留字。
5. 【强制】唯一索引名为 uk_字段名; 普通索引名则为 idx_字段名。
说明: uk_ 即 unique key; idx_ 即 index 的简称。
6. 【强制】小数类型为 decimal,禁止使用 float 和 double。
说明: float 和 double 在存储的时候,存在精度损失的问题,很可能在值的比较时,得到不
正确的结果。如果存储的数据范围超过 decimal 的范围,建议将数据拆成整数和小数分开存储。
7. 【强制】如果存储的字符串长度几乎相等,使用 char 定长字符串类型。
8. 【强制】 varchar 是可变长字符串,不预先分配存储空间,长度不要超过 5000,如果存储长
度大于此值,定义字段类型为 text,独立出来一张表,用主键来对应,避免影响其它字段索
引效率。
9. 【强制】表必备三字段: id, gmt_create, gmt_modified。
说明: 其中 id 必为主键,类型为 unsigned bigint、单表时自增、步长为 1。 gmt_create,
gmt_modified 的类型均为 date_time 类型。
10. 【推荐】表的命名最好是加上“业务名称_表的作用”。
正例: tiger_task / tiger_reader / mpp_config
11. 【推荐】库名与应用名称尽量一致。
12. 【推荐】如果修改字段含义或对字段表示的状态追加时,需要及时更新字段注释。
13. 【推荐】字段允许适当冗余,以提高性能,但是必须考虑数据同步的情况。冗余字段应遵循:
1) 不是频繁修改的字段。
2) 不是 varchar 超长字段,更不能是 text 字段。
正例: 商品类目名称使用频率高, 字段长度短,名称基本一成不变, 可在相关联的表中冗余存
储类目名称,避免关联查询。
14. 【推荐】单表行数超过 500 万行或者单表容量超过 2GB,才推荐进行分库分表。
说明: 如果预计三年后的数据量根本达不到这个级别,请不要在创建表时就分库分表。
15. 【参考】合适的字符存储长度,不但节约数据库表空间、节约索引存储,更重要的是提升检
索速度。
正例: 无符号值可以避免误存负数, 且扩大了表示范围。
- MYSQL建表规约
- MySQL建表规约
- 【Java开发手册之MySQL规约(一)】建表规约
- 阿里巴巴Java开发手册-MySQL约束-建表规约
- (一)建表规约
- Java开发代码规范之MySQL数据库(一)——建表规约
- MySQL设计规约
- mysql的索引规约
- MySQL索引规约
- 阿里巴巴开发秘籍:MYSQL规约
- 阿里巴巴开发秘籍:MYSQL规约
- 【Java开发手册之MySql规约(二)】索引规约
- 【Java开发手册之MySql规约(三)】SQL规约
- 【Java开发手册之MySql规约(四)】ORM规约
- 工作总结:数据库PO与建表规约【强制】
- 五、My SQL 数据库 (一)建表规约
- 【Mysql】《阿里巴巴Java开发手册(正式版)》--MySQL规约
- (三)阿里巴巴JAVA编程规范之MYSQL规约
- 基于js的简单队列实现
- 棋盘放车(DP状态压缩)
- Java多线程--内存模型
- React框架精髓
- 【C++】vector的使用方法
- MySQL建表规约
- pat 乙级 1008. 数组元素循环右移问题 (20)
- socket 实现点对点发送消息
- P1273 有线电视网
- Hibernate一级缓存和二级缓存的区别
- BZOJ 1790: [Ahoi2008]Rectangle 矩形藏宝地(CDQ分治+离散化+线段树)
- 第一部分:spring框架概述
- redis系列之数据库与缓存数据一致性解决方案
- Linux进程地址管理之mm_struct