如何在单个MongoDB查询结果中获取TotalCount和第一个文档?

发布于 2025-02-07 01:15:14 字数 588 浏览 0 评论 0原文

有一个过滤器myFilter用于获得有关XYZ集合的一些见解。 现在,我需要运行三个查询,该查询具有相同的步骤以过滤文档

db.xyz.find(myFilter).sort(mySort1).limit(1) // get first item by sort #1
db.xyz.find(myFilter).sort(mySort2).limit(1) // get first item by sort #2
db.xyz.find(myFilter).count()                // get total count

如何在单个查询或聚合中表达相同意图?

预期结果是

{
  "item_1": {/* first doc by (myFilter & mySort1) *//},

  "item_2": {/* first doc by (myFilter & mySort2) *//},

  "totalCount": /* count of all by myFilter */
}

There is a filter myFilter used to get some insights about the xyz collection.
Now I need to run three queries having the same step for filtering the documents

db.xyz.find(myFilter).sort(mySort1).limit(1) // get first item by sort #1
db.xyz.find(myFilter).sort(mySort2).limit(1) // get first item by sort #2
db.xyz.find(myFilter).count()                // get total count

How to express the same intention in a single query or aggregation?

Expected result is

{
  "item_1": {/* first doc by (myFilter & mySort1) *//},

  "item_2": {/* first doc by (myFilter & mySort2) *//},

  "totalCount": /* count of all by myFilter */
}

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

纸短情长 2025-02-14 01:15:14

您可以使用$ facet在一个查询中运行相同数据的几个管道:

db.collection.aggregate([
  {$match: myFilter}
  {$facet: {
    item_1: [{sort1}],
    item_2: [{sort2}],
    totalCount: [{$group: {_id: null, count: {$sum:1}}}]
  }}
])

You can use $facet to run several pipelines on the same data at one query:

db.collection.aggregate([
  {$match: myFilter}
  {$facet: {
    item_1: [{sort1}],
    item_2: [{sort2}],
    totalCount: [{$group: {_id: null, count: {$sum:1}}}]
  }}
])
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文