前言最近有不少前端和测试转Go的朋友在??交流群??里聊:如何做表结构设计?
大家关心的问题阳哥必须整理出来,希望对大家有帮助 。
4个方面设计数据库表结构需要考虑到以下4个方面:
- 数据库范式:通常情况下,我们希望表的数据符合某种范式,这可以保证数据的完整性和一致性 。例如,第一范式要求表的每个属性都是原子性的,第二范式要求每个非主键属性完全依赖于主键,第三范式要求每个非主键属性不依赖于其他非主键属性 。
- 实体关系模型(ER模型):我们需要先根据实际情况画出实体关系模型,然后再将其转化为数据库表结构 。实体关系模型通常包括实体、属性、关系等要素,我们需要将它们转化为表的形式 。
- 数据库性能:我们需要考虑到数据库的性能问题,包括表的大小、索引的使用、查询语句的优化等 。
- 数据库安全:我们需要考虑到数据库的安全问题,包括表的权限、用户角色的设置等 。
- 简单明了:表结构应该简单明了,避免过度复杂化 。
- 一致性:表结构应该保持一致性,例如命名规范、数据类型等 。
- 规范化:尽可能将表规范化,避免数据冗余和不一致性 。
- 性能:表结构应该考虑到性能问题,例如使用适当的索引、避免全表扫描等 。
- 安全:表结构应该考虑到安全问题,例如合理设置权限、避免SQL注入等 。
- 扩展性:表结构应该具有一定的扩展性,例如预留字段、可扩展的关系等 。
下面举个示例让大家更好的理解如何设计表结构,如何引入内存,有哪些优化思路:问题描述
文章插图
如上图所示,红框中的视频筛选标签,应该怎么设计数据库表结构?
这是一个很好的应用场景,大家可以先自己想一下 。不要着急看我的方案 。
需求分析
- 可以根据红框的标签筛选视频
- 其中综合标签比较特殊,和类型、地区、年份、演员等不一样
- 综合是根据业务逻辑取值,并不需要入库
- 类型、地区、年份、演员等需要入库
- 设计表结构时要考虑到:
- 方便获取标签信息,方便把标签信息缓存处理
- 方便根据标签筛选视频,方便我们写后续的业务逻辑
- 综合标签可以写到配置文件中(或者写在前端),这些信息不需要灵活配置,所以不需要保存到数据库中
- 类型、地区、年份、演员都设计单独的表
- 视频表中设计标签表的外键,方便视频列表筛选取值
- 标签信息写入缓存,提高接口响应速度
- 类型、地区、年份、演员表也要支持对数据排序,方便后期管理维护
注释
id
视频主键id
type_id
类型表外键id
area_id
地区表外键id
year_id
年份外键id
actor_id
演员外键id
其他和视频直接相关的字段(比如名称)我就省略不写了
类型表
注释
id
类型主键id
name
类型名称
sort
排序字段
推荐阅读
- 如何实现线程安全的HashMap?
- 如何在 Linux 命令行中查找最大的文件或文件夹
- PHP 如何使用函数实现类型转换
- 如何实现OT网络安全?
- 人工智能如何为数据中心团队带来新的日常工作
- Spring Boot启动了几个IoC容器?如何证明?
- 大裁员和ChatGPT来袭,IT行业员工如何"活下去"
- 自动驾驶汽车激光雷达如何做到与GPS时间同步?
- 孙俪|邓超孙俪被曝离婚后,女方庆祝喜事,男方冷漠无表态,无风不起浪!
- |如何与不同性格的人相处,建立良好合作关系:职场合作技巧的应用