首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

RavenDB 文档建模--建模注意事项

我们在开始讲解如何在 RavenDB 中建模之前,先来看看注意事项,这些内容与我们将要辨析的模型有着直接的关系。 这里需要注意的第一点是 不要在不同应用之间建立共享数据库。很多设计者会建立共享数据库,用以在不同的应用之间共享相同的数据,虽然这样做能减少数据存储量,以及实现多应用使用相同数据的目的,但是在 RavenDB 中并不推崇这样的做法。这是因为虽然不同的应用看起来有些数据是一样的,我们会强制它们使用相同的方式处理数据,但是在大多数情况下不同的应用程序使用相互不同的方式处理类似的数据,如果使用共享数据的话,一个应用程序共享数据的结构的改变就会造成其他应用跟着一起改变,进而导致数据模型复杂性增加,并且也会增加不同应用开发团队之间沟通的成本和时间。因此每个应用程序应该对立的进行数据建模,并不断的根据需求进行改进。 读到到这里,肯定有人会问了:不同的应用程序直接或多或少的都需要共享数据,那么使用 RavenDB 如何实现这一点呢?我们可以使用 RavenDB 内置的 ETL 功能在不同应用程序服务器之间建立数据/信息流(这个内容将会在后续讲解)。 另一个要注意的是 某些情况下应该数据冗余存储,比如在 Order 文档中存在 Address 文档的链接,但是如果 Address 中的配送地址变了,那么 Order 文档中的历史订单的配送地址也会跟着改变,这样就出现了我上一篇文章说的数据损坏。那么,我们在进行建模的时候,应该考虑我的关注点是当前值(例如 Order 文档中的当前订单配送地址)还是时间点值(例如 Order 文档的历史订单配送地址),如果是时间点值那么我们就需要进行数据冗余存储,例如在 Order 文档中存储配送地址的详细信息。 以上几小段的内容总结下来就是建模文档的核心原则:

02

基于JSON的Oracle数据库应用程序开发(与MongoDB兼容)

应用程序开发在一个不断变化的环境中进行。用户期望应用程序能够适应迅速变化的业务需求,并在应用程序演化时进行即时更新。所有这些意味着当应用程序发展时,开发人员需要具备最小停机时间或DBA参与的灵活数据持久性机制。关系模型缺乏这种灵活性:表具有静态的“形状”,应用程序更改需要修改表结构(例如添加新列),这通常涉及数据库管理员(DBA)。此外,现有数据可能需要进行修改以适应新的模式。更重要的是,关系方法需要事先设计模式:应用程序的对象(例如“客户订单”)被规范化为存储对象值的表和列。一个应用程序对象通常被规范化为多个表。这意味着现在简单的插入或获取操作需要插入并选择涉及所有参与表的操作,并具有正确的连接条件。开发人员必须理解此映射并使用SQL表达它。

03
领券