仅使用Pymongo获取有关(时间或ID)的最新文档

在MongoDB中,此技术通常用于获取有关(时间或ID)的最新文档:

 db.collection.find().sort({ "_id": -1 }).limit(1);

 MySchema.find().sort({ _id: -1 }).limit(1)

db.getLastInsertedDocument.find({}).sort({_id:-1}).limit(1);

但是当我使用pymongo在集合中查找最新条目时,下面的代码给出了错误。

from pymongo import MongoClient

import random
import datetime
import time
import pprint
from datetime import datetime
#from bson import ObjectId

client = MongoClient()
client = MongoClient('localhost',27017)
db = client.sensor_temperature # createdb
posts = db.posts2
print('Total Record for the collection: ' + str(posts.count()))

x=datetime.now().strftime("%H:%M:%S")

record=posts.find().sort({ "_id": -1 }).limit(1)  ###  ERR
#record=posts.find({"start_date":new Date()}).pretty() ####  ERR
#record=posts.findOne({"_id": x}) #### <pymongo.cursor.Cursor object at 0x0141FCD0>
pprint.pprint(record)
text=record
print(text)

如何仅使用Pymongo获取最新记录?

WUDEjiyi123 回答:仅使用Pymongo获取有关(时间或ID)的最新文档

某些pymongo驱动程序命令与mongodb shell并不完全匹配。 The documentation解释了方法调用。这应该起作用:

from pymongo import MongoClient,DESCENDING
<...>
record=posts.find().sort('_id',DESCENDING).limit(1)
pprint.pprint(list(record)[0])
本文链接:https://www.f2er.com/3144348.html

大家都在问