如何查找与特定条件匹配的记录的最近记录


    {
"_id" : ObjectId("5514ecc73910d3e808b9417c"),
"endingReciptBookNumber" : 2999,
"startingReciptBookNumber" : 2900,
"User" : 8,
"allRecipt" : [ 
    {
        "recipt_Number" : 2999,
        "amount" : 24124,
        "_id" : ObjectId("5514ecc73910d3e808b94180")
    }, 
    {
        "recipt_Number" : 100,
        "amount" : 2414,
        "_id" : ObjectId("5514ecc73910d3e808b9417f")
    }, 
    {
        "recipt_Number" : 101,
        "amount" : 242,
        "_id" : ObjectId("5514ecc73910d3e808b9417e")
    }, 
    {
        "recipt_Number" : 102,
        "amount" : 2424,
        "_id" : ObjectId("5514ecc73910d3e808b9417d")
    }
],
"__v" : 0

}

我在猫鼬的收藏中有很多这样的文件.我想查找特定用户的最新输入recipt_Number。就像在这种情况下,它应该给我 102 作为答案。

我还附加了几行代码。这也是获得相同结果的一种方式。

db.topics.find( {'User': 8}, { 'allRecipt': { $slice: -1 },'startingReciptBookNumber':0,'endingReciptBookNumber':0,'User':0,'_id':0,'__v':0 } )

查询结果如下

{
    "allRecipt" : [ 
        {
            "recipt_Number" : 102,
            "amount" : 2424,
            "_id" : ObjectId("5514ecc73910d3e808b9417d")
        }
    ]
}

虽然查询不会在结果中给出任何单个数字,但它会通过 result.allRecipt.0.recipt_Number 给出所需的结果,但您想要的数字将始终进入 0 索引。我认为这是您想要的数字。

在这里$slice有所作为。

谢谢

相关内容

  • 没有找到相关文章

最新更新