Próbuję użyć funkcji sortowania podczas wysyłania zapytań do mojej bazy danych mongoDB, ale kończy się to niepowodzeniem. To samo zapytanie działa w konsoli MongoDB, ale nie tutaj. Kod jest następujący:
import pymongo
from pymongo import Connection
connection = Connection()
db = connection.myDB
print db.posts.count()
for post in db.posts.find({}, {'entities.user_mentions.screen_name':1}).sort({u'entities.user_mentions.screen_name':1}):
print post
Otrzymuję następujący błąd:
Traceback (most recent call last):
File "find_ow.py", line 7, in <module>
for post in db.posts.find({}, {'entities.user_mentions.screen_name':1}).sort({'entities.user_mentions.screen_name':1},1):
File "/Library/Python/2.6/site-packages/pymongo-2.0.1-py2.6-macosx-10.6-universal.egg/pymongo/cursor.py", line 430, in sort
File "/Library/Python/2.6/site-packages/pymongo-2.0.1-py2.6-macosx-10.6-universal.egg/pymongo/helpers.py", line 67, in _index_document
TypeError: first item in each key pair must be a string
Znalazłem link w innym miejscu, który mówi, że muszę umieścić „u” przed kluczem, jeśli używam pymongo, ale to też nie zadziałało. Ktoś inny sprawi, że to zadziała, czy to jest błąd.
.sort([("field1",pymongo.ASCENDING), ("field2",pymongo.DESCENDING)])
aby posortować wiele pól.Możesz spróbować tego:
źródło
Działa to również:
Używam tego w moim kodzie, proszę o komentarz, jeśli robię coś źle, dzięki.
źródło
ASCENDING
iDESCENDING
frompymongo
. :)Dlaczego Python używa listy krotek zamiast dyktować?
W Pythonie nie możesz zagwarantować, że słownik zostanie zinterpretowany w zadeklarowanej kolejności.
Tak więc w powłoce mongo możesz to zrobić,
.sort({'field1':1,'field2':1})
a interpreter powinien posortować pole 1 na pierwszym poziomie, a pole 2 na drugim poziomie.Jeśli ten sintax był używany w Pythonie, istnieje szansa na sortowanie field2 na pierwszym poziomie. W przypadku krotki nie ma ryzyka.
źródło
Python używa klucza, kierunku. Możesz skorzystać z powyższego sposobu.
Więc w twoim przypadku możesz to zrobić
źródło
TLDR: potok agregacji jest szybszy w porównaniu z konwencjonalnym
.find().sort()
.A teraz przejdźmy do prawdziwego wyjaśnienia. Istnieją dwa sposoby wykonywania operacji sortowania w MongoDB:
.find()
i.sort()
.Jak sugeruje wiele .find (). Sort () jest najprostszym sposobem wykonania sortowania.
Jest to jednak proces powolny w porównaniu z potokiem agregacji.
Przechodząc do metody potoku agregacji. Kroki wdrażania prostego potoku agregacji przeznaczonego do sortowania są następujące:
UWAGA: Z mojego doświadczenia wynika, że potok agregacji działa nieco szybciej niż
.find().sort()
metoda.Oto przykład potoku agregacji.
Wypróbuj tę metodę samodzielnie, porównaj prędkość i daj mi znać w komentarzach.
Edycja: Nie zapomnij użyć
allowDiskUse=True
podczas sortowania na wielu polach, w przeciwnym razie spowoduje to błąd.źródło
Powiedzmy, że chcesz posortować według pola „created_on”, możesz to zrobić,
źródło