我试图使用RMongo从R查询mongo数据库,并返回一对嵌套文档的值。
通过查看RMongo的文档,我理解了以下查询:
output <- dbGetQueryForKeys(mongo, 'test_data', '{"foo": "bar"}', '{"foo":1}')争论的地方..。
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?
如何获得嵌套文档的密钥?如果我想要像..。
output <- dbGetQueryForKeys(mongo, 'test_data', '{"foo": "bar"}', '{"foo1.foo2.foo3.foo4":1,"foo1.foo2.foo3.bar4":1}')对于嵌套键,我现在返回的内容更像是.
X_id
1 50fabd42a29d6013864fb9d7
foo1
1 { "foo2" : { "foo3" : { "foo4" : "090909" , "bar4" : "1"}}}...where output[,2]是一个查找字符串,而不是与键foo4和bar4相关联的两个独立变量("090909“、"1")。
发布于 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+中聚合框架的一部分)来重塑和扁平结果输出。
发布于 2017-03-22 23:05:29
如果您的最终目标是从嵌套对象中提取R中某些类型的下游处理的值,这将使您达到这个目的。它避免了构建聚合管道,并且是解决问题的简单解决方案。不要试图深入嵌套结构并直接访问bar4,而是提取对象的顶层,它将提供您所引用的长字符串。
output <- dbGetQueryForKeys(mongo, 'test_data', '{"foo": "bar"}', '{"foo1.foo2.foo3.foo4":1,"foo1":1}')由于输出是一个data.frame,所以可以使用'jsonlite‘库来获取数据:
library(jsonlite)
foo1 <- fromJSON(output$foo1)
bar4 <- foo1$foo2$foo3$bar4https://stackoverflow.com/questions/14486780
复制相似问题