- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有 Orm 框架的经验,我开始了解 NoSql 数据库解决方案的结构。我将继续使用一些基于对象模型的示例。
我有以下文档模型,我想考虑一些场景处理。
public class Post
{
public string Title { get; set; }
public List<Tag> Tags { get; set; }
}
public class Tag
{
public string Name { get; set; }
}
关于我的场景,我的脑海中几乎没有出现问题。
Post 类是一个文档,将用标签保存。在 RDBMS 中,Tag 和 Post 具有多对多关系,但我知道它在 NoSql 中没有任何关系,因此 post 对象与整个成员一起保存。因此显示带有 post 计数场景的标签列表将导致整个 post 项目中的大量查询在每个查询中都付出一些努力,所以在这种情况下我不会失去 NoSql 功能的所有好处吗?
更新一个标签名会不会引起一些复杂的工作?我必须查询整个帖子项目并发现它具有该标签名称并更新它。顺便说一下,它需要多文档事务和漫长的过程,所以失败会导致我的数据库不一致,因为 NoSql 不支持多文档事务,所以我该如何处理?
我并不是要针对 RDBMS(Sql) 系统展示 NoSql 的缺点。我只是想了解我对这种情况的想法是否正确,可能有一些我错过的东西,或者看起来很糟糕的事情并不像我想的那样糟糕。我需要可扩展性,因此我对 NoSql 解决方案感兴趣。
最佳答案
起初,NoSQL 只是一个流行语,它涵盖了许多不同的数据库类型,例如键值存储、文档存储、图形数据库……参见 http://nosql-database.org/有关不同类型和实现的列表。其中一些系统还具有交易保证,例如对于您的情况,帖子已完全写入数据库。
我现在将关注键值存储,因为它们似乎是一个非常突出的 NoSQL 实例。
关于您的第一个问题:您是对的,人们不会在 RDBMS 中使用像外键这样的严格关系,但您只会保留与帖子实例关联的标签列表:
| pid | title | tags
| 1 | foo | sql, rdbms
| 2 | bar | sql, acid
...
为了按标签查询,您有一个所谓的倒排索引 ( http://en.wikipedia.org/wiki/Inverted_index ),它为您提供一个标签的所有文档 ID:
| tag | pids
| sql | 1, 2
| rdbms | 1
| acid | 2
这使得进行帖子计数变得非常容易。
更新标签名称实际上并没有那么复杂,如果你有一个基于 map-reduce 的数据访问,那么你可以,例如使用简单的作业(伪代码)将标签“Sql”更新为“SQL”:
map: IF post.tag contains('Sql') THEN emit(post)
reduce: in post.tag: replace('Sql' by 'SQL')
write(post)
但我不认为重命名标签是一件很常见的事情。 Brewer 在 CAP 定理 (http://en.wikipedia.org/wiki/CAP_theorem) 中陈述了处理时间长和不一致的问题,它基本上说你不能同时拥有一致性、可用性和分区容忍度,你必须至少交换一个对于另外两个。在你的情况下:如果你想对标签进行一致的更新(这样就不能读取两个文档,其中一个有标签“Sql”而另一个已经有“SQL”),你必须为其他人锁定表读者,因此您将没有空位。
最后的想法:如果你想构建一个高可用性、良好的扩展平台,你不想以关系的方式考虑太多。
关于c# - CRUD场景的NoSql更新机制,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7842092/
关闭。这个问题是opinion-based 。目前不接受答案。 想要改进这个问题吗?更新问题,以便 editing this post 可以用事实和引文来回答它。 . 已关闭 9 年前。 Improv
我刚刚发现了这门语言,我想知道是否可以使用数据库制作基本的 CRUD 网络应用程序。 最佳答案 有 mysql 的库和 postgresql , 核心库提供了一个 web server支持 HTTP、
Symfony 4.0 发布后,不再支持 SensioGeneratorBundle .因此命令 php app/console generate:doctrine:crud不可用。 他们建议使用 M
在开发 Web 应用程序时,我通常会看到人们执行增删改查和同步 View 的两种方式。 这里是使用 ajax 的高级示例。 1-方法一 创建操作可能涉及 POST 请求,成功后只需执行另一个 GET
我已经成功地使用 Yii2 模型和 CRUD 生成器为我的网络应用程序获取了一些框架代码文件。特别是,CRUD Generator 声称已成功将其 View 文件创建到: /basic/views//
在我的项目中,我一直在使用 Django 的通用 CRUD View 来处理很多事情。我现在想开始迁移到 DJango 1.3 中基于类的新样式通用 CRUD View 。我没有发现这些文档有多大帮助
关闭。这个问题需要details or clarity .它目前不接受答案。 想改进这个问题?通过 editing this post 添加详细信息并澄清问题. 7年前关闭。 Improve this
我希望标题不要太含糊,所以这里是: 我创建了一个 MySQL 数据库,其中存储了两个表:一个包含输入数据,另一个包含输出数据。 之后我编写了一个程序,连接到这个特定的数据库,从输入表中提取数据,解析它
我需要编辑我的实体以获得更多值。我已经用我之前的值生成了 crud。如何在编辑实体后通过应用程序/控制台重新生成 crud,以便它自动为其他值生成函数。 最佳答案 为此,您需要删除为此 crud 生成
因此,我仅使用 JavaScript 创建了一个简单的 CRUD 应用程序。现在,您可以将国家/地区添加到数组中并从数组中删除国家/地区。我希望能够编辑数组中的现有国家/地区,例如我想将“斯德哥尔摩”
我想让java中的一个类有一个可以与Hibernate配置交互并执行某些操作的方法,该方法被标识为ENUM(例如:读取,更新,添加,删除等) 方法参数应为(枚举操作、类 DTO、NamedQuery
我正在构建一个 React 应用程序,并使用 auth0 来登录/验证用户。 在使用 auth0 之前,我一直在对 API 进行 CRUD 调用来发布帖子。这又是在使用 auth0 之前、在我拥有用户
尝试使用 BlueJ 构建我的第一个 Java MySQL CRUD 应用程序。我可以运行该应用程序并将数据写入 MySQL 数据库。但是,当我运行搜索函数时,我得到了 Java .NullPoint
我正在试用 Microsoft Master Data Services,我想以编程方式将数据添加到数据库中。我开始获得模型/实体/成员结构,但我还不确定。如果您对此结构有很好的解释,请分享。 假设有
我正在尝试开发一个 Backbone Marionette 应用程序,我需要知道如何以最佳方式执行 CRUD(创建、读取、更新和销毁)操作。我找不到任何解释这一点的资源(仅适用于 Backbone)。
我已经根据文档和 medium article 模拟了与 Room 的多对多关系。 .使用这个@Relation,我可以从数据库中检索RecipeWithIngredients 或Ingredient
Closed. This question is opinion-based。它当前不接受答案。 想要改善这个问题吗?更新问题,以便editing this post用事实和引用来回答。 3年前关闭。
通过AngularJS通过REST进行CRUD操作的最佳实践是什么? 特别是这里的 Angular-Way 。我的意思是使用最少代码和最默认 Angular 设置来达到此目的的方式。 我知道$ res
我无法弄清楚我的更新功能。我能够从数据库中检索和删除,但我不知道如何更新。这对我来说是全新的,所以我很困惑。 .js 文件 //update user $("#btnUpdateUser").clic
我正在寻找一种对用户透明的 CRUD 操作后重新加载页面的方法。 实际上,在创建或删除之后,我必须重新加载页面才能显示我的操作。 我使用 api 来实现这个,当我将它与 json 文件一起使用时,它工
我是一名优秀的程序员,十分优秀!