博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
数据库设计之半结构化存储
阅读量:7071 次
发布时间:2019-06-28

本文共 460 字,大约阅读时间需要 1 分钟。

    业务场景:用户填一些单据。然后上报,完毕审批。

单据中有几个字段是须要统计的,业务并不复杂。

    看似简单的场景。当开发者拿出PDM设计的时候,我惊呆了,密密麻麻的有接近70张表。每张表都是一百多个字段。开发者抱怨,花了一周的时间来做数据库设计,实在是太麻烦了。

     设计方案1,我问能不能把单据进行归类,一类单据设计成一张表,用一个字段区分是那张单据,这样会降低非常多表。

得到的回复是,没法归类。方案1行不通。

     设计方案2。做个Excel模板,审批的时候就在excel上审批,问题是有字段要做统计,行不通。

     设计方案3,单据的内容使用JSON格式用blob存起来。假设要做统计的字段,做经常使用条件查询的字段。从blob中冗余出来专做统计。

     总结:选择方案3是大大的降低了开发者的工作量,但对业务分析人员的要求非常高,能识别出来哪些字段做分析、统计,哪些字段做查询。丢失了传统数据库设计的非常多长处。是设计非常多时候都在做平衡,这样的设计无疑降低工作量。但对查询、统计不友好。假设你不在乎工作量。我还是建议做成最传统的设计。

转载地址:http://oskml.baihongyu.com/

你可能感兴趣的文章
Python中元组、列表、字典的遍历和相互转化
查看>>
SmoothWall的小企业应用
查看>>
FOSCommentBundle功能包:设置Doctrine ORM映射(投票)
查看>>
Enterprise Library Step By Step系列(十五):配置应用程序块——设计篇
查看>>
Visio中插入公式
查看>>
对于软件生产能解决到痛点的容器技术就是好!Wise2C睿云智合如何运行
查看>>
SharePoint 2013 状态机工作流之扩展自定义状态
查看>>
物联网下的工控机产业发展迅速 潜力正不断被挖掘
查看>>
云上数据安全,初识数据库审计
查看>>
微信中的video属性设置
查看>>
第一篇:linux系统应用管理之用户的切换
查看>>
haproxy负载均衡
查看>>
MySQL GEO 字段类型说明及案例
查看>>
Java中内存分配
查看>>
使用JDBC处理LOB大型对象
查看>>
我的友情链接
查看>>
Centos VirtualBox安装
查看>>
DICOM医学图像显示算法改进与实现
查看>>
eclipse配置tomcat
查看>>
性能测试
查看>>