首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >RMongo dbGetQueryForKeys(),“键”的结构是什么?

RMongo dbGetQueryForKeys(),“键”的结构是什么?
EN

Stack Overflow用户
提问于 2013-01-23 18:30:05
回答 2查看 747关注 0票数 1

我试图使用RMongo从R查询mongo数据库,并返回一对嵌套文档的值。

通过查看RMongo的文档,我理解了以下查询:

代码语言:javascript
复制
output <- dbGetQueryForKeys(mongo, 'test_data', '{"foo": "bar"}', '{"foo":1}')

争论的地方..。

代码语言:javascript
复制
db = mongo
collection = 'test_data'
query = '{"foo": "bar"}'
keys = 'Specify a set of keys to return.'

'{"foo":1}'中的1是什么?这个键集的结构是什么?对照这篇博客文章,我发现了一种格式,如:

结果<- dbGetQueryForKeys(mongo,"items","{'publish_date‘:{ '$gte’:'2011-04-01','$lt‘:’2011-05-01‘}“,"{'publish_date’:1,‘$gte’:1}")

那么,很明显,钥匙需要值1?

如何获得嵌套文档的密钥?如果我想要像..。

代码语言:javascript
复制
output <- dbGetQueryForKeys(mongo, 'test_data', '{"foo": "bar"}', '{"foo1.foo2.foo3.foo4":1,"foo1.foo2.foo3.bar4":1}')

对于嵌套键,我现在返回的内容更像是.

代码语言:javascript
复制
                      X_id
1 50fabd42a29d6013864fb9d7
                                                                               foo1
1 { "foo2" : { "foo3" : { "foo4" : "090909" , "bar4" : "1"}}}

...where output[,2]是一个查找字符串,而不是与键foo4和bar4相关联的两个独立变量("090909“、"1")。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2013-04-13 15:49:57

{“foo”:1}中的1是什么?这个键集的结构是什么?

这些键是返回在查询投影中的读操作的MongoDB。"1“的值意味着包含特定字段,而"0”不包括。默认行为是包括投影中的所有字段。

如何获得嵌套文档的密钥? 对于嵌套键,我现在返回的内容更像是.1{ "foo2“:{ "foo3”:{ " foo4“:"090909”," bar4“:”1“}} ...where输出,2是一个查找字符串,而不是与键foo4和bar4相关联的值的两个独立变量("090909","1")。

RMongo驱动程序正在返回数据,包括嵌入的hiearchy。

您可以使用RMongo dbAggregate()命令和$project操作符(这是MongoDB 2.2+中聚合框架的一部分)来重塑和扁平结果输出。

票数 0
EN

Stack Overflow用户

发布于 2017-03-22 23:05:29

如果您的最终目标是从嵌套对象中提取R中某些类型的下游处理的值,这将使您达到这个目的。它避免了构建聚合管道,并且是解决问题的简单解决方案。不要试图深入嵌套结构并直接访问bar4,而是提取对象的顶层,它将提供您所引用的长字符串。

代码语言:javascript
复制
output <- dbGetQueryForKeys(mongo, 'test_data', '{"foo": "bar"}', '{"foo1.foo2.foo3.foo4":1,"foo1":1}')

由于输出是一个data.frame,所以可以使用'jsonlite‘库来获取数据:

代码语言:javascript
复制
library(jsonlite)
foo1 <- fromJSON(output$foo1)
bar4 <- foo1$foo2$foo3$bar4
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/14486780

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档