返回同一字段的更多计数

发布于 2025-02-08 11:55:11 字数 434 浏览 1 评论 0原文

给定以下文档:

[
  {
    "user": "A",
    "feedback":"like"
  },
  {
    "user": "B",
    "feedback":"dislike"
  },
  {
    "user": "C",
    "feedback":"like"
  },
  {
    "user": "D",
    "feedback":"like"
  },
  {
    "user": "E",
    "feedback":"dislike"
  },
]

我想获得喜欢和不喜欢的数量。

在这种情况下,我会得到{LikesCount:3,frikikeScount:2}

如何使用猫鼬实现这一目标?

Given the following document:

[
  {
    "user": "A",
    "feedback":"like"
  },
  {
    "user": "B",
    "feedback":"dislike"
  },
  {
    "user": "C",
    "feedback":"like"
  },
  {
    "user": "D",
    "feedback":"like"
  },
  {
    "user": "E",
    "feedback":"dislike"
  },
]

I would like to get likes count and dislikes count.

In this case I would get {likesCount: 3, dislikesCount: 2}.

How can I achieve this using Mongoose?

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

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

发布评论

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

评论(1

陈甜 2025-02-15 11:55:11

查询

  • 假设反馈,并且仅是
  • null(所有集合1组)的两个值组之一
    (无效是一个常见的选择,关键是按常数分组
    “ _ ID”:“ Hello”会执行相同的
  • 总和,如果像添加到LikeScount 1一样,否则添加0
    (不喜欢的情况相同)

yourColl.aggregate(
[{"$group": 
   {"_id": null,
    "likesCount": 
     {"$sum": {"$cond": [{"$eq": ["$feedback", "like"]}, 1, 0]}},
    "dislikesCount": 
     {"$sum": {"$cond": [{"$eq": ["$feedback", "dislike"]}, 1, 0]}}}}])

Query

  • assuming that feedback and only be one of those 2 values
  • group by null (all collection 1 group)
    (null is a common choice, the point is to group by a constant
    "_id" : "hello" would do the same)
  • and 2 sums, if its like add to likesCount 1, else add 0
    (the same for the dislikes)

Playmongo

yourColl.aggregate(
[{"$group": 
   {"_id": null,
    "likesCount": 
     {"$sum": {"$cond": [{"$eq": ["$feedback", "like"]}, 1, 0]}},
    "dislikesCount": 
     {"$sum": {"$cond": [{"$eq": ["$feedback", "dislike"]}, 1, 0]}}}}])
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文