【问题标题】:mongodb slice - remove last n elementsmongodb slice - 删除最后 n 个元素
【发布时间】:2020-07-17 16:20:33
【问题描述】:

假设我有以下数组:

{
   data: [1, 0, 4, 0, 0, 4, 1, 3, 0, 1, 0, 2, 2, 0, 1, 1, 0, 2, 0, 4, 1, 1, 0, 1, 1, 0]
}

如何选择除最后 3 个以外的所有元素?

使用db.find({},{ "_id": 0, "data": {'$slice': [-3, 3] }})

我可以排除最后 3 个元素,但是我不能选择所有其他元素,因为如果 skip 是负数或 |skip|高于 list.length 则返回最后三个元素,就好像 skip==0

如何选择除最后 3 个以外的所有元素?

期望的结果:

[1, 0, 4, 0, 0, 4, 1, 3, 0, 1, 0, 2, 2, 0, 1, 1, 0, 2, 0, 4, 1, 1, 0]

【问题讨论】:

    标签: mongodb pymongo


    【解决方案1】:

    使用 MongoDb 聚合,我们可以使用$size 运算符来计算data 的长度:

    db.collection.aggregate([
      {
        $project: {
          "_id": 0,
          "data": {
            "$slice": [ 
              "$data",
              0,
              {
                $subtract: [ { $size: "$data" }, 3 ]
              }
            ]
          }
        }
      }
    ])
    

    MongoPlayground

    注意:如果data可以为空,我们需要添加$max操作符

    {
      $max: [
        {
          $subtract: [
            { $size: "$data" },
            3
          ]
        },
        1
      ]
    }
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 2023-02-09
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多