使用 MongoDb 具有多租户集合的 Atlas 全文搜索 ($searchBeta)

Using MongoDb Atlas full text search with multi-tenant collection ($searchBeta)

我有一个 MongoDb 集合,其中包含数千个租户的数据,这些数据由包含租户 ID 的字段分隔。
我想对特定租户执行包含全文搜索和分面的查询(见下文)。
由于 $searchBeta 必须是聚合管道中的第一阶段,这意味着它将 return 来自所有租户的大量文档列表只是为了在 $match 阶段过滤掉它们而不是使用索引。
有没有更有效的方法来执行这样的查询?
运行 它与 $searchBeta 一起使用需要 14 秒,而删除它将查询时间减少到 6 毫秒(而分面适用于更多文档,因为它包含所有租户的数据)。
* 使用下面道格的回答将其减少到 ~70-120 毫秒。
* 时间测量是在 Atlas 免费层上完成的,所以它并不意味着太多

db.tenantData.aggregate( [
{
    $searchBeta: {
        "search": {
        "query": "test",
        "path": ["name","comment"],
      }
    }
},
{
    $match: {tenant:"tenant1"},
},
{
    $facet: {
        "AssetTypeFacet": [
          { $sortByCount: "$assetType" }
        ],
        "manufacturerFacet": [
          { $sortByCount: "$manufacturer" }
        ]
    }
}
])    

您可以将查询组合成一个 compound,如下所示:

db.tenantData.aggregate([
  {
    $searchBeta: {
      compound: {
        should: {
          search: { query: "test", path: ["name", "comment"] },
        },
        filter: {
          search: { query: "tenant1", path: "tenant" },
        },
      },
    },
  },
  {
    $facet: {
      AssetTypeFacet: [{ $sortByCount: "$assetType" }],
      manufacturerFacet: [{ $sortByCount: "$manufacturer" }],
    },
  },
]);

这将消除与 $match 关联的 IO。目前没有办法直接在 $searchBeta 中进行分面,除非您已经这样做了。