首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在一对多关系中查找查询

在一对多关系中查找查询
EN

Stack Overflow用户
提问于 2017-05-31 19:51:30
回答 1查看 970关注 0票数 0

支持我的文档结构如下

代码语言:javascript
复制
var order = {
order_id : "1234",
plan_name: "Basic plan",
app_id:["app-id-1","app-id-2"]
}

它有一对多的关系结构。我把它插入到mongo中,如下所示

代码语言:javascript
复制
db.orders.insert(order) 

我还在order_idapp_id上创建了索引。现在,我有一个app_id,我想找到它的order_id

如何编写查询来查找我知道我需要使用db.orders.find({"app_id":""}),但app_id是一个数组。或者有没有我遗漏的其他技巧?

EN

回答 1

Stack Overflow用户

发布于 2017-05-31 20:37:17

您可以通过多种方式查询数组。如果想要在app_id数组中查找所有以app-id-1为值的订单,可以简单地查询

代码语言:javascript
复制
app_id: "app-1-id" 

这将返回数组中包含该值的所有订单。如果要查找具有一组应用程序ids的所有订单,您可以查询

代码语言:javascript
复制
app_id: {$all: <array_of_app_ids>}

要查找只包含一组特定ids而不包含其他ids的所有订单,可以将$all与$size配对

代码语言:javascript
复制
app_id: {$all: <array_of_app_ids>, $size: <array_of_app_ids.length>}

但是,如果传递单个值,mongoDB将返回数组中包含该值的所有条目

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

https://stackoverflow.com/questions/44284055

复制
相关文章

相似问题

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