[英]mongodb query in 2 collections
我像这样在一个mongo db中分别在2个集合中定义了2个reconds
order:
{
"_id" : ObjectId("53142f58c781abdd1d836fcd"),
"number" : "order1",
"user" : ObjectId("53159bd7d941aba0621073e3")
}
user
{
"_id" : ObjectId("53159bd7d941aba0621073e3"),
"name" : "user1",
"gender" : "male"
}
当我在控制台中使用此命令时,它无法执行db.orders.find({user:db.user ['_ id']})或db.orders.find({user:user ['_ id']}),
有什么问题吗? 谢谢!
另一种方法是:
> var user = db.users.findOne({name: 'user1'});
> db.orders.find({user: user._id});
这种方式可以稍微灵活一些,特别是如果您要退回多个用户的订单等时。
发表您的评论:
谢谢,但是实际上,我想搜索所有用户的所有订单,而不仅仅是一个用户。 那我该怎么办? 谢谢
db.users.find().forEach(function(doc){
printJson(db.orders.find({user: doc._id}));
});
我想你要:
db.order.find({'user':db.users.findOne({'name':'user1'})._id})
您需要做的就是查询并在将输出插入查询之前检查输出。
即检查:
db.users.findOne({'name':'user1'})._id
具有输出:
ObjectId("53159bd7d941aba0621073e3")
如果要运行较大的查询,则必须更改结构。 请记住,Mongodb不执行联接,因此您需要创建一个如下所示的用户文档:
user
{
"name":"user1",
"gender":"male",
"orders":[
{
'number':'order1'
}
]
}
然后,您可以使用以下方法更新此内容:
db.user.update({'_id':ObjectId('blah')}, {'orders':{$push:{'number':'order2'}})
然后,您将开始进行订单跟踪。
Mongo将能够使用以下内容进行查找:
db.user.find({'orders.numbers':'order2'})
返回完整的用户记录
也许您可以帮助解决方案:
use orders
db.getCollection('order').find({},{'_id':1})
db.getCollection('user').find({},{'_id':1})
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.