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小项目-第四节课
数据库·sql·mysql
探索宇宙真理.5 分钟前
Grafana SQL表达式漏洞 | CVE-2026-27876概念复现&研究
数据库·sql·grafana
Roc-xb7 分钟前
Windows MySQL 密码忘记了如何重置密码?
windows·mysql
七七powerful15 分钟前
MySQL 8.0 性能优化利器:Percona Toolkit 实战指南
数据库·mysql·性能优化
成为大佬先秃头9 小时前
数据库连接池:Druid
数据库·mysql·druid
晓华-warm12 小时前
Warm-Flow 1.8.5 正式发布:超时自动审批、暂存功能来了!
数据库
u01368638213 小时前
将Python Web应用部署到服务器(Docker + Nginx)
jvm·数据库·python
light blue bird13 小时前
多页签Razor组支轴业务整顿组件
数据库·.net·ai大数据·多功能图表报表·web mvc + razor
wregjru13 小时前
【mysql】2.数据表操作
数据库·mysql
手握风云-13 小时前
基于 Java 的网页聊天室(三)
服务器·前端·数据库