我有一个现有的程序,我正在尝试获取与键匹配的最后插入的文档aws_account_id
using find_one
在皮蒙戈。
我正在使用此查询来执行获取:
report = securitydb.scout.find_one({'aws_account_id': aws_account.account_number})
但此查询返回错误的文档。下图展示了我得到的预期结果和错误结果。
在图像中,两个文档具有相同的 aws_account_id,但红色文档最后插入。因此,预期结果是红色标记的文档,但它拉出黄色标记的文档。
我不确定是否需要使用排序或类似的东西。我得到了一些解决方案,但这些解决方案基于纯 mongo 查询。我需要帮助用 pymongo 来做这件事。
提前致谢,
罗宾
Use sort
in the *args
for find_one() https://api.mongodb.com/python/current/api/pymongo/collection.html#pymongo.collection.Collection.find_one
report = securitydb.scout.find_one(
{'aws_account_id': aws_account.account_number},
sort=[( '_id', pymongo.DESCENDING )]
)
Using _id
这里因为ObjectId
值在添加时总是会“增加”,但是任何其他像“日期”这样也表示“最新”的东西都可以使用,只要它在DESCENDING
排序顺序,这意味着“最新”位于结果的“顶部”。
You can import pymongo
如果您还没有这样做并使用pymongo.DESCENDING
令牌,或者只是-1
表示“降序”顺序。前者可能会使代码更加清晰。
另请注意“有序字典”,因为“排序”的键顺序通常很重要,或者至少如果您想对多个键的组合进行排序。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)