dongpiao0731 2015-04-24 13:24
浏览 12
已采纳

在MongoDB中查找最新对象

I have data in MongoDB in the form of :

 {
            "_id" : 154,
            "record_id" : "001280000033x54AAA",
            "jsonData" : "",
            "user_id" : 1,
            "userName" : "abc@xyz.com",
            "backup_no" : 1
 }


 {
            "_id" : 155,
            "record_id" : "001280000033x54AAA",
            "jsonData" : "",
            "user_id" : 1,
            "userName" : "abc@xyz.com",
            "backup_no" : 2
 }
  ...

I want to retrieve data based on 'user_id','userName', but if a record with same record_id exists in lower 'backup_no' then i need to choose record with highest backup_no.

I have tried to aggregate record_id's and then query but i am unable to find a solution.

Thanks

  • 写回答

2条回答 默认 最新

  • dpecb06062 2015-04-24 13:47
    关注

    Using mongo aggregation you can get your results check below query :

    db.collectionName.aggregate({
      "$sort": {
        "backup_no": -1 //first sort by backup_no 
      }
    }, {
      "$group": {
        "_id": "$record_id", // group by record_id so here only get distinct record_id
        "userId": {
          "$first": "$user_id"
        },
        "userName": {
          "$first": "$userName"
        },
        "backup_no": {
          "$first": "$backup_no"
        }
      }
    }, {
      "$project": {
        "_id": 0,
        "record_id": "$_id",
        "user_id": "$user_id",
        "userName": "$userName",
        "backup_no": "$backup_no"
      }
    })
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 基于卷积神经网络的声纹识别
  • ¥15 Python中的request,如何使用ssr节点,通过代理requests网页。本人在泰国,需要用大陆ip才能玩网页游戏,合法合规。
  • ¥100 为什么这个恒流源电路不能恒流?
  • ¥15 有偿求跨组件数据流路径图
  • ¥15 写一个方法checkPerson,入参实体类Person,出参布尔值
  • ¥15 我想咨询一下路面纹理三维点云数据处理的一些问题,上传的坐标文件里是怎么对无序点进行编号的,以及xy坐标在处理的时候是进行整体模型分片处理的吗
  • ¥15 CSAPPattacklab
  • ¥15 一直显示正在等待HID—ISP
  • ¥15 Python turtle 画图
  • ¥15 stm32开发clion时遇到的编译问题