表结构设计-1 (字段)

需要遵循规范化、字段设计、索引设计、主键设计和关联设计等原则。

这里记录字段相关经验。

字段冗余设计

反范式设计:设计表及其字段之间的关系, 应尽量满足第三范式。但是有时候,可以适当冗余

使用场景:查询设计(空间换时间) ;虚拟外键关联(代码外键关联);业务快照

转载

命名规范

数据库表名、字段名、索引名等都需要命名规范,可读性高(一般要求用英文),让别人一看命名,就知道这个字段表示什么意思

选择合适的字段类型

根据数据类型选择字段类型:不同的数据类型应该使用不同的字段类型。

  • 整数型数据可以使用INT或BIGINT类型
  • 浮点型数据可以使用 FLOAT或DOUBLE
  • 类型字符型数据可以使用VARCHAR或CHAR类型

考虑数据长度

字段类型应该根据所需存储的数据长度来选择。

如果某个字段的数据长度不会超过 10 个字符,则可以使用 CHAR(10)类型代替VARCHAR(50)类型,以节省空间。

如果存储的值太大,建议字段类型修改为text,同时抽出单独一张表,用主键与之对应

注意精度和小数位数。

对于需要精确数值计算的字段(如货币和百分比),应该选择带有精度和小数位数的字段类型(如 DECIMAL)。

在mysql中,varchar和char类型表示字符长度,而其他类型表示的长度都表示字节长度。

char(10)表示字符长度是10。(例如,存储 "hello" 时,剩余的 6 个字符会以空格符填充。)

bigint (4)表示显示长度是4个字节,但是因为bigint实际长度是8个字节,所以bigint (4)的实际长度就是8个字节(位数不足时会在左侧填充 0 直到满足位数要求)。

所以在设计表时需要充分考虑一个字段的长度,比如一个用户名字段 (它的长度5~20个字符)可以考虑设置为 varchar (32)。需要注意字段长度一般设置为2的n次方。

考虑数据完整性

字段类型也应该考虑到数据完整性。

日期型数据应该使用DATE或DATETIME类型,以确保输入的日期格式正确

主键设计要合理

主键的设计在数据库中非常重要,它用于唯一标识表中的每一行数据,并且在数据操作和查询中起到关键作用。通常主键的设计,不要与业务相关联,因为业务是会发生变化的,应当使用自增的 id,并且保持主键的连续性。如果说是分布式系统可以使用优化的雪花id 等等

注意:不推荐使用uuid当主键(会带来性能、索引效率等问题)

优先考虑逻辑删除,而不是物理删除

物理删除:把数据从硬盘中删除,可释放存储空间

逻删除:给数据添加一个字段,比如is deleted,以标记该数据已经逻辑删除

物理删除会带来以下问题:

数据恢复困难

物理删除会导致索引树重构

每个表都需要添加通用字段

一个表除了添加业务字段还应该加入通用字段比如:

id: 主键,一个表必须得有主键,必须

creat_time: 创建时间

creator:创建人

update_time:修改时间,必须,更新记录时,需要更新它

update_by :修改人,非必须

remark:数据记录备注,非必须


原文链接:https://blog.csdn.net/qq_62262918/article/details/135877062

相关推荐
半夏知半秋4 分钟前
Elasticsearch Query DSL 指令整理
大数据·数据库·笔记·学习·elasticsearch·搜索引擎·全文检索
元气满满-樱9 分钟前
SQL语句***重点
数据库·sql
doris61011 分钟前
设备点检、保养、维修一站式解决方案
大数据·数据库·人工智能
数据库学啊13 分钟前
车联网时序数据库哪家专业
数据库·时序数据库
半夏知半秋29 分钟前
Elasticsearch专用的ES|QL语法指令整理
大数据·数据库·elasticsearch·搜索引擎·全文检索
DBA小马哥37 分钟前
信创背景下国产数据库选型指南:聚焦Oracle迁移场景的深度对比
数据库·oracle
赵渝强老师1 小时前
【赵渝强老师】国产金仓数据库的逻辑存储结构
数据库·postgresql·国产数据库·kingbase·人大金仓
TT哇2 小时前
【Database Navigator 插件】idea 社区版连接 mysql 数据库
java·数据库·mysql·intellij-idea·database
workflower2 小时前
PostgreSQL 数据库的典型操作
数据结构·数据库·oracle·数据库开发·时序数据库
正在走向自律2 小时前
AiOnly平台x FastGPT:一键调用Gemini 3 Pro系列模型从零构建AI工作流
大数据·数据库·人工智能·aionly·nano banana pro·gemini 3 pro