热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

如何在pymongo中使用find_one获取最新记录

如何解决《如何在pymongo中使用find_one获取最新记录》经验,为你挑选了1个好方法。

我有一个现有的程序,我正在尝试获取最后插入的文件,该文件与pymongo中aws_account_id使用的密钥相匹配find_one.

我正在使用此查询来执行提取:

report = securitydb.scout.find_one({'aws_account_id': aws_account.account_number})

但是此查询返回错误的文档.下图显示了我得到的预期结果和错误的结果.

在此输入图像描述

在图像中,两个文档都具有相同的aws_account_id,但最后插入了红色文档.所以预期的结果是红色标记的文件,但它拉出黄色标记的文件.

我不确定我是否需要使用排序或类似的东西.我得到了一些解决方案,但这些都是基于纯mongo查询.我需要帮助用pymongo这样做.

谢谢提前,罗宾



1> Neil Lunn..:

使用sort*argsfind_one()

report = securitydb.scout.find_one(
  {'aws_account_id': aws_account.account_number},
  sort=[( '_id', pymongo.DESCENDING )]
)

_id在这里使用是因为ObjectId值在添加时总是会"增加",但是只要它在DESCENDING排序顺序中就可以使用任何其他类似"日期"的东西,它也表示"最新" ,这意味着"最新"是在结果的"顶部".

您可以,import pymongo如果您还没有这样做并使用pymongo.DESCENDING令牌,或只是-1为了表示"降序".前者可能会提供更清晰的代码.

另请注意"有序字典",因为"排序"键的顺序通常很重要,或者至少如果要对多个键的组合进行排序.


推荐阅读
author-avatar
吕骥源_342
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有