首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在mongolite R库中获取ObjectID

在mongolite R库中获取ObjectID
EN

Stack Overflow用户
提问于 2015-12-18 16:59:35
回答 3查看 2.2K关注 0票数 6

我可以成功地从我的mongoDB实例中检索数据,但是需要为依赖的查询重用objectID。

下面的代码似乎得到了我的整个对象,但没有得到id。我遗漏了什么?

代码语言:javascript
复制
# Perform a query and retrieve data
mongoOBj <- m$find('{"em": "test@test.com"}')
EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2015-12-20 17:18:45

如果查看文献资料,就会发现find方法采用field参数,其中指定了所需的字段:

代码语言:javascript
复制
find(query = ’{}’, fields = ’{"_id" : 0}’, sort = ’{}’, skip = 0, limit = 0, handler = NULL, pagesize = NULL)

所以在你的情况下

代码语言:javascript
复制
mongoOBj <- m$find(query = '{"em": "test@test.com"}', field = '{"_id": 1}')
票数 6
EN

Stack Overflow用户

发布于 2018-01-09 14:19:15

我意识到这是个老生常谈的问题,OP现在可能已经弄明白了,但我认为答案应该是

代码语言:javascript
复制
mongoOBj <- m$find(query = '{"em": "test@test.com"}', field = '{}') 

而不是

代码语言:javascript
复制
mongoOBj <- m$find(query = '{"em": "test@test.com"}', field = '{"_id": 1}')

在第二种情况下,结果将是一个仅包含ID的数据帧。第一行将生成包含查询数据(包括ID)的数据帧。

默认情况下,field = '{"_id": 0}',意味着_id不是输出的一部分。

票数 10
EN

Stack Overflow用户

发布于 2019-03-04 22:38:07

因此,获取所有字段的最简单方法是使用field="{}“执行查询。这将覆盖mongolite::package ()参数列表中的默认值。

有一段时间我也快疯了。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/34360439

复制
相关文章

相似问题

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