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的分享

相关推荐
flypwn33 分钟前
TFCCTF 2025 WebLess题解
服务器·前端·数据库
n***i9540 分钟前
云原生数据库使用体验,与传统数据库差异
数据库·云原生
百***99247 小时前
MySql的慢查询(慢日志)
android·mysql·adb
q***13347 小时前
在linux(Centos)中Mysql的端口修改保姆级教程
linux·mysql·centos
理想三旬7 小时前
关系数据库
数据库
千寻技术帮8 小时前
50022_基于微信小程序同城维修系统
java·mysql·微信小程序·小程序·同城维修
无心水9 小时前
【分布式利器:RocketMQ】2、RocketMQ消息重复?3种幂等方案,彻底解决重复消费(附代码实操)
网络·数据库·rocketmq·java面试·消息幂等·重复消费·分布式利器
q***985210 小时前
基于人脸识别和 MySQL 的考勤管理系统实现
数据库·mysql
l1t10 小时前
用SQL求解advent of code 2024年23题
数据库·sql·算法
办公解码器11 小时前
Excel工作表打开一次后自动销毁文件,回收站中都找不到
数据库·excel