当前位置: 首页 > news >正文

可扩展性表设计方案

文章目录

  • 1 使用预留字段
  • 2 使用JSON字段
  • 3 使用单表继承
  • 4 构建属性表
  • 5 直接构建新表
  • 6 适当冗余

1 使用预留字段

在表设计初期,可以预留一些命名通用的备用字段,例如field1、field2、field3。当业务需要增加新字段时,就直接使用这些预留字段,无需修改表结构。

例如用户表预留5个扩展字段,新需求需要记录用户注册渠道,可以直接使用field1存放,不影响旧数据和业务。

  • 优点:适用于需求变化较小、对表结构影响较小的场景。可以将部分非关键数据放在预留字段,实现轻量级扩展。
  • 缺点:备用字段数量的选择,备用字段在备用时的格式设置,这些选择都是在设置备用字段时需要考量的因素,且备用字段的设置不一定能很好的满足后期的扩展需要。

2 使用JSON字段

JSON支持内嵌文档格式,可在一个字段存储更多结构化信息。当需要新增属性时,直接在JSON字段加入新属性即可,不影响旧数据。

  • 优点:适用于需要存储结构化扩展信息的场景。可在JSON中嵌套存储对象或数组,扩展灵活。
  • 缺点:以JSON格式进行存储,数据特征不明显,数据库层面对数据格式的限制缺失,对数据存储的规范不能很好做出制定。

3 使用单表继承

在需要扩展时创建新表继承父表,同时加入特有字段。在查询时通过多表合并实现表的可扩展性。

MySql在设计实现继承关系时,在每个子表中设计一个指向父表的外键,使子表和父表之间产生一种“is-a”的关系。

  • 优点:适用于同主题的类似数据类型,需要区分但相关度很高的不同业务表。通过继承关系可以有效的减少冗余度。

4 构建属性表

设置主表和属性表,在属性表中通过主表类型+属性名作为联合主键,通过key字段和value字段存储主表之中的扩展信息,扩展新属性通过增加属性表记录即可实现扩展,不影响主表的使用。

  • 优点:适用于主体部分和扩展属性松耦合的场景。通过主表存储强耦合主体,属性表存储可扩展信息,解耦扩展属性的影响。

5 直接构建新表

直接构建新表,旧表数据通过脚本或触发器的方式写入新表中。在升级过程中,旧功能可通过触发器写入新表,新功能直接写入新表的方式完成平滑升级。

  • 优点:适用于对旧表影响太大、需要全新表结构的场景。通过触发器等继承旧数据,实现平滑衔接。

6 适当冗余

在数据库表设计时,根据需求场景和经验进行适当的冗余性设置,满足日后的扩展字段构建需要。

http://www.lryc.cn/news/169404.html

相关文章:

  • Scotch: Combining SGX and SMM to Monitor Cloud Resource Usage【TEE的应用】
  • 腾讯mini项目-【指标监控服务重构】2023-08-19
  • go实现grpc-快速开始
  • linux上的init 0-6指令作用以及一些快捷键和系统指令
  • Mixin 混入
  • pycharm快捷键
  • 【面试刷题】——Linux基础命令
  • 第四步 Vue2 配置ESLint
  • [.NET学习笔记] - Thread.Sleep与Task.Delay在生产中应用的性能测试
  • 【单线图的系统级微电网仿真】基于 PQ 的可再生能源和柴油发电机组微电网仿真(Simulink)
  • 人脸识别技术应用安全管理规定(试行)|企业采用人脸打卡方式,这4条规定值得关注
  • leetcode 817. 链表组件(java)
  • 分布式事务基础理论
  • 《打造高可用PostgreSQL:策略与工具》
  • 【八大经典排序算法】快速排序
  • vue 父组件给子组件传递一个函数,子组件调用父组件中的方法
  • docker 获取Nvidia 镜像 | cuda |cudnn
  • uTool快捷指令
  • R reason ‘拒绝访问‘的解决方案
  • 许战海战略文库|品类缩量时代:制造型企业如何跨品类打造份额产品?
  • BIT-4-数组
  • L9945的H桥续流模式
  • Ubuntu20.04安装Nvidia显卡驱动、CUDA11.3、CUDNN、TensorRT、Anaconda、ROS/ROS2
  • linux下使用crontab定时器,并且设置定时不执行的情况,附:项目启动遇到的一些问题和命令
  • linux下二进制安装docker最新版docker-24.0.6
  • 计算机视觉 01(介绍)
  • Java下部笔记
  • 链表基本操作
  • Linux学习笔记-Ubuntu系统下配置用户ssh只能访问git仓库
  • 央媒发稿不能改?媒体发布新闻稿有哪些注意点