Mysql 数据库 开发规范

(一)建表规约

强制规约

  1. 表达是否概念的字段

使用 is_xxx(is_used) 的方式命名

  1. 若字段的数据类型为非负数

类型则为 unsigned

  1. 若字段的数据类型为 unsigned tinyint

1表示是,0 表示否

4 . 表名、字段名需 使用小写字母 或 数字

正例:getter_admin , task_config , level3_name

反例:GetterAdmin , taskConfig , level_3_name

  1. 表名不能使用负数

正例: user

反例: users

  1. 字段不能使用 mysql 保留字

例如:ADD、ALL、ALTER、ANALYZE、AND、AS、ASC、

BEFORE、BETWEEN等

  1. 唯一索引

使用 uk_字段名

  1. 普通索引

使用 idx_字段名

  1. 小数类型

正例: decimal

反例: float、double 存储时存在精度损失问题

若存储的数据范围超过 decimal 的 范围, 建议将将数据拆成整数和小数分开存储

  1. 存储的 字符串长度 几乎相等

使用 定长char类型

  1. varchar 字符串长度 > 5000

改使用 text类型 避免影响 其他字段的索引效率

建议规约

  1. 推荐 表的命名 "业务名称_表的作用"

正例: tiger_task/tiger_reader/mpp_config

  1. 数据库名 应与 应用名称 一致

  2. 如果修改字段, 需要加上注释

  3. 单表行数超过500万行或者单表容量超过2GB,才推荐进行分库分表。

说明:如果预计三年后的数据量根本达不到这个级别,请不要在创建表时就分库分表。

  1. 合适的字符存储长度,不但节约数据库表空间、节约索引存储,更重要的是提升检

索速度。

正例:人的年龄用unsigned tinyint(表示范围0-255,人的寿命不会超过255岁);

海龟就必须是smallint,

太阳的年龄,就必须是int;

如果是所有恒星的年龄都加起来,那么就必须使用bigint。

(二)索引规约

之后更新

(三)SQL规约

之后更新

【注】参考阿里巴巴开发手册 第三节

资料获取:

链接:https://pan.baidu.com/s/11FmO-NoYs7jyfSw8lxcn1w

提取码:ylnb

--来自百度网盘超级会员V3的分享

相关推荐
徐子元竟然被占了!!4 小时前
Linux-systemctl
linux·数据库·oracle
YJlio6 小时前
Active Directory 工具学习笔记(10.8):AdInsight——保存与导出(证据留存、共享与二次分析)
数据库·笔记·学习
suoyue_zhan6 小时前
GBase的管理监控平台GEM实践指南
数据库
哈哈老师啊7 小时前
Springboot学生综合测评系统hxtne(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
java·数据库·spring boot
小小8程序员7 小时前
Redis-10
数据库·redis·缓存
liuzhilongDBA7 小时前
从collation mismatch异常到其原理
数据库·version·glibc·postgres·collation
梁萌7 小时前
MySQL数据库分库分表介绍
数据库·mysql·shardingsphere·分库分表
占疏8 小时前
dify API访问工作流/聊天
开发语言·数据库·python
Cat God 0079 小时前
SQL使用及注意事项
数据库·sql·mysql