码农知识堂 - 1000bd
Python
PHP
JS/TS
JAVA
C/C++
C#
GO
Kotlin
Swift
MySQL表结构设计规范
一、表设计
1. 命名规范
表名由
小写英文字母
和
下划线
组成
表必须填写描述信息
表名中的英文单词应该使用单数形式
临时表以 tmp 为前缀,以日期为后缀
备份表以 bak 为前缀,以日期为后缀
使用hash、md5 进行散表,表名后缀使用16进制
2. 设计规范
必须定义主键,一般默认为id,整型自增
主键不允许修改,一般采用业务无关字段
表必须包含
gmt_create
和
gmt_modified
字段记录创建时间和修改时间
禁止使用外键
慎用触发器和存储过程。将业务逻辑放到应用层更合适
单条记录禁止超过 8kb
单表列数一般不超过50
单表数据量建议控制在500万行一下、2GB内
3. 字段设计
在满足数据存储和扩展需要的前提下,尽量使用更小的数据类型
在表
达是否概念时,使用 is_xxx 形式命
名
建立索引的字段必须定义为 not null,并设置 default
存储小数尽量使用decimal,避免丢失精度
避免使用小数存储金额,一般转换为最小单位的整数倍存储
避免使用 text、blob 存储大文本
、文件、图片,应使用文件系统存储
varchar 要根据业务实际需要进行长度控制
。虽然在存储层面根据实际长度存储,但在内存分配时是根据指定长度,不合理的长度设计会导致内存分配不合理
4. 索引设计
选择区分度高的字段作为索引项
避免在频繁更新的字段上建索引
单表索引建议控制在5个以内
在varchar字段上建立索引时,必须指定索引长度
,没必要对全字段建索引
建立联合索引时要根据左前缀原则避免冗余,其次要把区分度高的字段放在前面
相关阅读:
像用Excel一样用Python:pandasGUI
【分布式搜索引擎elasticsearch】
java毕业设计网站基于JSP的在线调查问卷系统|投票[包运行成功]
一文看懂Ngnix内存池源码 附带详细讲解,清晰结构图
微服务模式:服务发现模式
Redis入门:Redis持久化策略RDB&AOF简介
MySQL双主模式(2022/11/19)
nvidia-smi常用选项汇总
windows下Redis-cluster集群搭建
七、鼎捷T100应收帐款之期末帐务处理
原文地址:https://blog.csdn.net/wanger61/article/details/132762920
最新文章
攻防演习之三天拿下官网站群
数据安全治理学习——前期安全规划和安全管理体系建设
企业安全 | 企业内一次钓鱼演练准备过程
内网渗透测试 | Kerberos协议及其部分攻击手法
0day的产生 | 不懂代码的"代码审计"
安装scrcpy-client模块av模块异常,环境问题解决方案
leetcode hot100【LeetCode 279. 完全平方数】java实现
OpenWrt下安装Mosquitto
AnatoMask论文汇总
【AI日记】24.11.01 LangChain、openai api和github copilot
热门文章
十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
奉劝各位学弟学妹们,该打造你的技术影响力了!
五年了,我在 CSDN 的两个一百万。
Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
面试官都震惊,你这网络基础可以啊!
你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
心情不好的时候,用 Python 画棵樱花树送给自己吧
通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
13 万字 C 语言从入门到精通保姆级教程2021 年版
10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系
2656653265@qq.com
京ICP备2022015340号-1
正则表达式工具
cron表达式工具
密码生成工具
京公网安备 11010502049817号