如何解决mongomock 聚合 $lookup 不会像真正的 mongo db (python)
cursor = db.my_db['shop'].aggregate([
{
'$lookup':
{
'from': 'customer','localField': 'in_shop','foreignField': '_id','as': 'joined_customers'
}
}
])
请注意,此查询使用其他集合 customer
及其 from
子句。
此查询对实际的 mongo db 非常有效,但对我的 mongomock.mognoClient
对象无效。
为了让它与 mongomock 一起工作,我需要将数据库前缀添加到查询中,如下所示:
cursor = db.my_db['shop'].aggregate([
{
'$lookup':
{
'from': 'my_db.customer','as': 'joined_customers'
}
}
])
但是,如果我这样做,此查询将不再适用于实际的 mongo DB。 这里出了什么问题?我无法创建同时适用于模拟和实际数据库的代码。
如果我不包含数据库名称,模拟不会找到其他集合来加入它。需要明确的是,这两个查询在各自的“系统”上都可以正常工作,并且可以在模拟中单独查询这两个集合。如果 customer
子句不包含数据库名称前缀,则仅在 mongomock 中查找 from
集合将无法正常工作。
解决方法
我发现了这个问题。我模拟了导入的包而不是导入包中的数据库。这实际上导致了类似 Database(Database(Collection()))
的结果,而它应该只是 Database(Collection())
。所以它毕竟与 mongomock
没有任何关系。
我想学习的是嵌套数据库是可能的,并且由于它们的行为就像导入包中的变量一样,因此直到内部函数尝试交叉引用另一个集合时才会显示错误。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。