当前位置: 首页 > 面试题库 >

Cassandra和CouchDB有什么区别?

伍弘盛
2023-03-14
问题内容

我正在看两个项目,但我看不出有什么区别

来自Cassandra网站:
Cassandra是一个高度可扩展的,最终一致的,分布式的,结构化的键值存储库… Cassandra最终是一致的。与BigTable一样,Cassandra提供的基于ColumnFamily的数据模型比典型的键/值系统更丰富。

从CouchDB网站:
Apache CouchDB是可通过RESTful HTTP / JSON API访问的分布式,容错和无模式的面向文档的数据库。

也就是说,我将每个项目之间的特定区别视为:访问方法,书面语言等。但是举个例子,当您谈论SOLR或Sphinx时,您知道两者都是索引器,两者之间有很大差异,但最后是索引器。

我可以在这里说Cassandra和CouchDB是非关系数据库,在某些情况下一个可以替代另一个数据库吗?


问题答案:

CouchDB是一个文档存储。您将文档(JSON对象)放入其中,并在其上定义视图(索引)。这些对象可能具有潜在的深层结构,因此可能是任意复杂的。此外,它们不限于遵循某些一致的模式。

Cassandra是一个破烂的表键值存储。它仅存储行,每个行都有一组命名列,这些命名列分组为具有值的族。听起来与BigTable非常接近;BigTable不需要每一行都具有相同的结构(不同于SQL数据库)。这些值可能具有某种结构,但是这种存储对此一无所知-它们只是字符串/字节序列。

是的,它们都是非关系数据库,并且在适用性上可能存在很多重叠,但是它们确实具有截然不同的数据组织模型。每个模型都可能被迫模仿另一个模型,但是每个模型将最好地映射到一组不同的问题。



 类似资料:
  • Cassandra CQL中的Varchar和text数据类型有什么不同。 https://docs.datastax.com/en/cql/3.0/cql/cql_reference/cql_data_types_c.html DESC测试表给出了下面的结果。 [cqlsh 5.0.1 Cassandra 3.0.7.1158 DSE 5.0.0 CQL spec 3.4.0 Native pr

  • 主要内容:CRDBMS:关系数据库管理系统,NoSQL数据库CouchDB是由Apache软件基础开发的开源NoSQL数据库,它是用Erlang编程语言编写的。 有两种类型的数据库: 关系数据库管理系统(遵循SQL) NoSQL CRDBMS:关系数据库管理系统 RDBMS是基于E.F. Codd引入的关系模型。它是SQL的基础,大多数数据库系统遵循RDBMS。 一些常见的数据库是:Oracle,MySQL,MS SQL Server,IBM DB2和Mi

  • 问题内容: 两者都意味着空间,但是有什么区别吗? 问题答案: 一个是不间断空间,另一个是常规空间。不间断的空格表示该行不应在该点处换行,就像它不会在一个单词的中间换行一样。 此外,正如斯文德(Svend)在其评论中指出的那样,不间断的空间不会崩溃。

  • 本文向大家介绍<%# %> 和 <% %> 有什么区别?相关面试题,主要包含被问及<%# %> 和 <% %> 有什么区别?时的应答技巧和注意事项,需要的朋友参考一下 答:<%# %>表示绑定的数据源 <%%>是服务器端代码块  

  • 问题内容: 各种NoSQL数据库的优缺点是什么? 特别是,在跨多个服务器分配写负载时,Redis似乎很弱。是这样吗 这是个大问题吗?在此成为严重问题之前,服务必须增长多少? 问题答案: NoSQL数据库(以及SQL数据库)的优缺点在 很大程度上 取决于您的用例。对于大型项目,性能为准;但是对于全新的项目或时间和金钱有限的项目,简单性和上市时间可能是最重要的。对于自学(拓宽视野,成为更好,更有价值的

  • 问题内容: 以下代码之间有什么区别: 和 Python建议采用一种做事方式,但有时似乎不止一种。 问题答案: 一个是函数调用,一个是文字: 使用第二种形式。它更具Python风格,并且可能更快(因为它不涉及加载和调用单独的函数)。