202

为什么我应该使用像 CouchDB 这样的基于文档的数据库而不是使用关系数据库。是否存在基于文档的数据库比关系数据库更适合的典型应用程序或领域?

4

7 回答 7

181

可能你不应该:-)

第二个最明显的答案是,如果您的数据不是关系数据,您应该使用它。这通常表现为没有简单的方法将您的数据描述为一组列。一个很好的例子是您实际存储纸质文档的数据库,例如通过扫描办公室邮件。数据是扫描的 PDF,您有一些始终存在的元数据(扫描于、扫描于、文档类型)和许多可能存在的元数据字段(客户编号、供应商编号、订单编号、保留文件直到, OCRed 全文等)。通常您事先不知道您将在未来两年内添加哪些元数据字段。对于这种数据,CouchDB 之类的东西比关系数据库好得多。

我个人也喜欢这样一个事实,即我不需要任何 CouchDB 的客户端库,除了 HTTP 客户端,现在几乎所有编程语言都包含它。

可能最不明显的答案:如果您使用 RDBMS 没有任何痛苦,请继续使用它。如果您总是需要围绕 RDBMS 来完成工作,那么面向文档的数据库可能值得一看。

有关更详细的列表,请查看Richard Jones 的此帖子

于 2009-01-20T22:21:48.427 回答
47

CouchDB(来自他们的网站

  • 一个文档数据库服务器,可通过 RESTful JSON API 访问。通常,关系数据库不是简单地通过 REST 服务访问,而是需要更复杂的 SQL API。通常这些 API(JDBC、ODBC 等)非常复杂。REST 非常简单。

  • 具有平坦地址空间的 Ad-hoc 和无模式。关系数据库具有复杂、固定的模式。你定义表、列、索引、序列、视图和其他东西。Couch 不需要这种复杂、昂贵、脆弱的高级计划。

  • 分布式,具有强大的增量复制和双向冲突检测和管理功能。一些 SQL 商业产品提供此功能。由于 SQL API 和固定模式,这是复杂、困难和昂贵的。对于 Couch 来说,它看起来既简单又便宜。

  • 可查询和可索引,具有使用 Javascript 作为查询语言的面向表的报告引擎。SQL 和关系数据库也是如此。这里没有什么新鲜事。

所以。为什么选择 CouchDB?

  • REST 比 JDBC 或 ODBC 更简单。
  • 没有 Schema 比 Schema 更简单。
  • 以一种看似简单且便宜的方式分发。
于 2009-01-14T00:36:39.777 回答
29

用于愚蠢地存储和提供其他服务器数据。

在过去的几周里,我一直在玩一个 lifestream 应用程序,它会轮询我的提要(delicious、flickr、github、twitter...)并将它们存储在 couchdb 中。couchdb 的美妙之处在于它让我可以将原始数据保持在其原始结构中,而不会产生任何开销。我为每个文档添加了一个“类”字段,存储源服务器,并为每个源编写了一个 javascript 渲染类。

概括地说,每当您的服务器与另一台服务器通信时,最好使用无模式存储,因为您无法控制模式。作为奖励,couchdb 使用服务器和客户端的本机协议 - JSON 用于表示,HTTP REST 用于传输。

于 2009-02-15T09:47:43.040 回答
22

快速应用程序开发浮现在脑海中。

当我不断地发展我的模式时,我总是因为必须在 MySQL/SQLite 中维护模式而感到沮丧。虽然我还没有对 CouchDB 做太多事情,但我确实喜欢在 RAD 过程中演化模式是多么简单。

当您有很多多对多关系时,您可能不想使用非关系数据库。我还没有弄清楚如何围绕这些类型的关系创建良好的 MapReduce 函数,特别是如果您需要在连接关系中包含元数据。我不确定,但我不认为 CouchDB Map 函数可以在数据库上调用自己的查询,因为这可能会导致无限循环。

于 2009-01-22T03:13:33.627 回答
7

当您不需要将数据存储在每个记录具有统一大小字段的表中时,请使用基于文档的数据库。相反,您需要将每条记录存储为具有某些特征的文档。可以随时将任意长度的任意数量的字段动态添加到文档中,而无需先“修改表格”。基于文档的字段也可以包含多条数据。

于 2010-01-27T02:49:14.703 回答
1

详细说明 smdelfin:灵活性。您可以以任何结构(非结构化和所有)存储数据,并且每个文档都可以完全不同。CouchDB 特别有用,因为使用它们的“视图”索引,您可以过滤掉特定文档并在需要数据库的这些子集时仅查询该视图。

我在以 JSON 格式存储数据的文档数据库中最大的赢家是:这是 JavaScript 的原生格式。因此,JavaScript Web 应用程序与 CouchDB 配合得非常好。我最近制作了一个使用 CouchDB 的 Web 应用程序,它速度飞快,同时还能够处理不断变化的数据结构。

于 2019-10-31T18:55:59.810 回答
0

基于文档的数据库比关系数据库有很大的优势,因为它们不需要在能够输入任何数据之前预先定义模式。

此外,如果您的数据不是关系数据并且不能存储在表格中而是一组图像或例如报纸文章,则应该使用文档数据库。

另一个优点是在 Web 开发中易于使用基于文档的数据库。有关更深入的 NoSQL 数据库模型,请查看以下来源:https ://arxiv.org/ftp/arxiv/papers/1509/1509.08035.pdf

于 2020-05-03T16:22:55.093 回答