mongodb - 有没有办法比较 MongoDB 查询中的两个字段

标签 mongodb mongodb-query

如果我有一个名为 game 的集合,它具有这样的架构。

{"team": "A", "opponent": "B", "points": 101, "opp_points": 100}
{"team": "B", "opponent": "A", "points": 100, "opp_points": 101}

有没有办法查询同一集合中两个字段之间的比较?

等效的 SQL 是。

SELECT * FROM game where points > opp_points;

我查看了 Mongo 的文档并没有找到这个,但我认为他们可能有。

最佳答案

在聚合或 $find 中的 $match 中使用 $expr

db.collection.aggregate([
  {
    $match: {
      $expr: {
        $gt: [
          "$points",
          "$opp_points"
        ]
      }
    }
  }
])

工作 Mongo playground聚合

db.collection.find({
  $expr: {
    $gt: [
      "$points",
      "$opp_points"
    ]
  }
})

工作 Mongo playground的发现

关于mongodb - 有没有办法比较 MongoDB 查询中的两个字段,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/66405856/

相关文章:

MongoDb Ops Manager 无法启动 mongos 和分片

java - 根据 mongo db 中的字符串列表过滤提交的字符串

MongoDB : text index with arrays, 只有第一项被编入索引

mongodb - 将两个字段合并为一个对象

node.js - 查找后在对象数组中设置字段。蒙古数据库

MongoDB : How to update a new field value according to existing field value in each document?

MongoDB:如何找到已安装 MongoDB 的确切版本

mongodb - 如何使用多个键有效地执行 "distinct"?

node.js - 使用 $min 选择字段的最小值并在 mongodb 中聚合

C# Mongo Driver 批量文件替换