gpt4 book ai didi

Mongodb 在一次往返中执行多个查询

转载 作者:可可西里 更新时间:2023-11-01 10:09:07 27 4
gpt4 key购买 nike

是否有类似 elasticsearch Multi Search API 的东西?链接是:https://www.elastic.co/guide/en/elasticsearch/reference/current/search-multi-search.html .

假设我有多个查询,我想将这些查询提供给 mongo 并按顺序获得结果。

最佳答案

是的,MongoDB 中有类似的东西。使用聚合框架,您可以在 $facet 中定义多个聚合管道阶段。

尝试:

db.col.save({a:1})
db.col.save({a:2})


db.col.aggregate([
{
$facet: {
query1: [ { $match: { a:1 } }, { $project: { _id: 0 } } ],
query2: [ { $match: { a:2 } }, { $project: { _id: 0 } } ],
}
}
])

打印:

{ "query1" : [ { "a" : 1 } ], "query2" : [ { "a" : 2 } ] }

使用 $facet 你必须记住单个 BSON 文档的大小不能超过 16 MB。有关聚合限制的更多信息 here

关于Mongodb 在一次往返中执行多个查询,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52913008/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com