Получить последний документ относительно (времени или идентификатора), используя только Pymongo - PullRequest
0 голосов
/ 07 ноября 2019

В 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?

1 Ответ

0 голосов
/ 07 ноября 2019

Некоторые команды драйвера pymongo не совсем соответствуют оболочке mongodb. Документация объясняет вызовы метода. Это должно работать:

from pymongo import MongoClient, DESCENDING
<...>
record=posts.find().sort('_id', DESCENDING).limit(1)
pprint.pprint(list(record)[0])
...