敏捷开发下, 由 User Story 中设计: 保证数据一致性的数据库表结构

过往的数据库设计思维∵强调整体,主要是期望借由所谓的整体,使数据库设计可保证数据的 Integrity

但这样的思维,在面向对象的世界里,往往因类设计时,类责任的不明确,而因为对象的存取破坏了数据的 Integrity

所以,数据库设计真正的重点,不在所谓的整体。而在明确

我在产品级敏捷,设计了一个实践;Story 场景树。

借由 Story 场景树,分析每个 Story下的场景,明确界定 Entity 校验的纬度,所以,每个 Entity 的定义便是明确的,每个 Entity 间的关系也是明确的。

所以,由各 Story 所分析出的 EntityValue Object 便可形成与数据表相匹配的数据表结构,以提升数据的 Integrity

Story 场景树,轻量级,可视化,可适用于敏捷开发下的团队协作。

Story 场景树主要是分析:Story 内部的活动,活动后所生成的 EntityEntity 校验的纬度,Story 调用的接口。

所以,从 Story 场景树中,自然便会得知各 Entity 是从何而来?该如何定义(校验)?对外的依赖为何?

有了上述的信息,自然可分析出各 Entity 间是关联包含的关系,而可分析出数据表中的 Primary/Forient Key

上述,是从领域  “广度的面向,由 Entity 间设计数据表 (Table)

另一方面,各 Entity 都会有 Properties 来描述。Properties 便会形成 Value Objecs。而 Entity 的 Value Objects 便形成由领域深度,设计数据表结构;也许就会形成 record 的字段设计。

当然,更讲究的会再进行正规化的设计。


  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值