gpt4 book ai didi

mongodb - 带有 ColdFusion、Bean+Service+DAO 和 OOP 的 NoSQL 还是好的旧数组/结构和过程?

转载 作者:可可西里 更新时间:2023-11-01 09:13:52 26 4
gpt4 key购买 nike

您如何使用 NoSQL 构建简单、灵活、高效和干净的 CF 后端模型?

由于 NoSQL 文档没有像 SQL 行那样的固定模式,因此它不太适合相当静态的对象。因此,典型的 Bean+DAO+Service OOP 架构似乎不太适合。

我正在考虑使用普通的旧 Struct,但我无法向其添加行为,这将使整个项目非常程序化,这可能不是一件坏事?

但是,如果我只使用普通的旧结构,数据库实现就会泄露到任何地方,包括 View 层...

或者...我应该将数组转换为 View 层的 CF 查询对象吗?

评论?主意?建议?

谢谢!

最佳答案

我在 CF 中编写了几个使用 NoSQL 数据存储的应用程序 - 一个使用 Google App Engine 数据存储,另一个使用 MongoDB。

在这两种情况下,我都将 CFC 作为我的对象。但是,我使用了一个自制的对象“框架”,它使用 onMissingMethod 作为访问器,并使用带有大量自定义元数据的 cfproperty 来定义对象的属性。

例如,这就是我需要为模型定义的全部内容,除非它具有自定义业务逻辑:

<cfcomponent output="false" persistentLayer="GAE" persistentClass="asana" extends="com.bespokelogic.framework.BaseModel">
<cfproperty name="id" type="string" persistentDatatype="string" settable="true" gettable="true" required="true">
<cfproperty name="deckSet" type="string" persistentDatatype="string" settable="true" gettable="true" default="basic">
<cfproperty name="englishName" type="string" persistentDatatype="string" settable="true" gettable="true">
<cfproperty name="traditionalName" type="string" persistentDatatype="string" settable="true" gettable="true">
<cfproperty name="pronunciation" type="string" persistentDatatype="string" settable="true" gettable="true">
<cfproperty name="anatomicalFocus" type="array" persistentDatatype="array" settable="true" gettable="true" default="#arrayNew(1)#">
<cfproperty name="therapeuticFocus" type="array" persistentDatatype="array" settable="true" gettable="true" default="#arrayNew(1)#">
<cfproperty name="benefits" type="string" persistentDatatype="string" settable="true" gettable="true">
<cfproperty name="variations" type="string" persistentDatatype="string" settable="true" gettable="true">
<cfproperty name="contraindications" type="array" persistentDatatype="array" settable="true" gettable="true" default="#arrayNew(1)#">
<cfproperty name="skill" type="string" persistentDatatype="string" settable="true" gettable="true">
<cfproperty name="instructions" type="string" persistentDatatype="string" settable="true" gettable="true">
</cfcomponent>

CFC 都扩展了一个基本模型,该模型具有验证、序列化、反序列化和虚拟 getter/setter 方法。

然后,我有一个持久层,它知道如何从数据存储中获取对象或将对象放入数据存储中。

然后我会为每个使用持久层的模型编写一个服务。

结果是模型知道如何序列化它们的属性数据,而持久层知道如何将其放入数据存储区。

因此,从某种意义上说,它不是一个对象关系管理器,而更像是一个对象文档管理器。

该框架在现实中功能更全面,因为我的设计是我采用一些模型,并将它们保存在 SQL 中,一些保存在 NoSQL 中,所有这些都在同一个应用程序中——我可以在不重新编码的情况下交换底层数据存储的应用程序。这是部分成功。

在您的情况下,如果您使用单个数据存储,则可以跳过所有那些复杂的东西。

你只需要一个知道如何序列化和反序列化模型的基础对象,以及你的 getter/setter 东西。决定您希望如何在 CFC 中存储属性数据。我使用了一个名为“variables.instance._properties{}”的结构

然后为您的模型编写一个具有“put”和“fetch”方法的服务。例如,“put”方法接受一个模型,对其调用“serialize”方法将其转换为 JSON,然后将其填充到 Mongo 中。 “fetch”方法获取 Mongo 记录,创建 CFC 的新实例,并将 Mongo 记录传递给反序列化方法。

那是相当漫无边际的......

TL;DR:“CF 中的对象(例如它们)并不是真的那么静态。使用 CFC。使用 onMissingMethod 允许动态属性。以允许您将它们序列化和反序列化为一种格式的方式存储属性(通常是 JSON),它很容易被您的数据存储区消化。编写一个简单的持久层,从数据存储区获取文档或将文档放入/从数据存储区中取出。编写实现您的持久层并获取和返回动态模型的简单服务。

在我看来,CF 非常适合 NoSQL。

关于mongodb - 带有 ColdFusion、Bean+Service+DAO 和 OOP 的 NoSQL 还是好的旧数组/结构和过程?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4622121/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com