अजगर MongoDB - क्रमबद्ध करें
किसी संग्रह की सामग्री को पुनर्प्राप्त करते समय, आप उन्हें उपयोग करके आरोही या अवरोही क्रमों में क्रमबद्ध और व्यवस्थित कर सकते हैं sort() तरीका।
इस पद्धति के लिए, आप फ़ील्ड (एस) और सॉर्टिंग क्रम जो 1 या -1 पास कर सकते हैं। जहां, 1 आरोही क्रम के लिए है और -1 अवरोही क्रम है।
वाक्य - विन्यास
निम्नलिखित प्रकार () विधि का वाक्यविन्यास है ।
>db.COLLECTION_NAME.find().sort({KEY:1})
उदाहरण
मान लें कि हमने एक संग्रह बनाया है और उसमें 5 दस्तावेज़ डाले हैं जैसा कि नीचे दिखाया गया है -
> use testDB
switched to db testDB
> db.createCollection("myColl")
{ "ok" : 1 }
> data = [
... {"_id": "1001", "name": "Ram", "age": "26", "city": "Hyderabad"},
... {"_id": "1002", "name": "Rahim", "age": 27, "city": "Bangalore"},
... {"_id": "1003", "name": "Robert", "age": 28, "city": "Mumbai"},
... {"_id": "1004", "name": "Romeo", "age": 25, "city": "Pune"},
... {"_id": "1005", "name": "Sarmista", "age": 23, "city": "Delhi"},
... {"_id": "1006", "name": "Rasajna", "age": 26, "city": "Chennai"}
]
> db.sample.insert(data)
BulkWriteResult({
"writeErrors" : [ ],
"writeConcernErrors" : [ ],
"nInserted" : 6,
"nUpserted" : 0,
"nMatched" : 0,
"nModified" : 0,
"nRemoved" : 0,
"upserted" : [ ]
})
निम्नलिखित पंक्ति संग्रह के सभी दस्तावेजों को पुनः प्राप्त करती है जो आयु के आधार पर आरोही क्रम में क्रमबद्ध होते हैं।
> db.sample.find().sort({age:1})
{ "_id" : "1005", "name" : "Sarmista", "age" : 23, "city" : "Delhi" }
{ "_id" : "1004", "name" : "Romeo", "age" : 25, "city" : "Pune" }
{ "_id" : "1006", "name" : "Rasajna", "age" : 26, "city" : "Chennai" }
{ "_id" : "1002", "name" : "Rahim", "age" : 27, "city" : "Bangalore" }
{ "_id" : "1003", "name" : "Robert", "age" : 28, "city" : "Mumbai" }
{ "_id" : "1001", "name" : "Ram", "age" : "26", "city" : "Hyderabad" }
अजगर का उपयोग कर दस्तावेजों को छाँटना
आरोही में किसी क्वेरी के परिणामों को क्रमबद्ध करने के लिए, अवरोही क्रम pymongo प्रदान करता है sort()तरीका। इस पद्धति के लिए, परिणाम में आपके द्वारा आवश्यक दस्तावेजों की संख्या का प्रतिनिधित्व करने वाला एक संख्या मान पास करें।
डिफ़ॉल्ट रूप से, यह विधि निर्दिष्ट क्षेत्र के आधार पर दस्तावेजों को आरोही क्रम में क्रमबद्ध करती है। यदि आपको फ़ील्ड नाम के साथ अवरोही क्रम पास -1 क्रमबद्ध करना होगा -
coll.find().sort("age",-1)
उदाहरण
निम्नलिखित उदाहरण संग्रह के सभी दस्तावेजों को आरोही क्रम में आयु मानों के अनुसार व्यवस्थित करते हैं -
from pymongo import MongoClient
#Creating a pymongo client
client = MongoClient('localhost', 27017)
#Getting the database instance
db = client['b_mydb']
#Creating a collection
coll = db['myColl']
#Inserting document into a collection
data = [
{"_id": "1001", "name": "Ram", "age": "26", "city": "Hyderabad"},
{"_id": "1002", "name": "Rahim", "age": "27", "city": "Bangalore"},
{"_id": "1003", "name": "Robert", "age": "28", "city": "Mumbai"},
{"_id": "1004", "name": "Romeo", "age": 25, "city": "Pune"},
{"_id": "1005", "name": "Sarmista", "age": 23, "city": "Delhi"},
{"_id": "1006", "name": "Rasajna", "age": 26, "city": "Chennai"}
]
res = coll.insert_many(data)
print("Data inserted ......")
#Retrieving first 3 documents using the find() and limit() methods
print("List of documents (sorted in ascending order based on age): ")
for doc1 in coll.find().sort("age"):
print(doc1)
उत्पादन
Data inserted ......
List of documents (sorted in ascending order based on age):
{'_id': '1005', 'name': 'Sarmista', 'age': 23, 'city': 'Delhi'}
{'_id': '1004', 'name': 'Romeo', 'age': 25, 'city': 'Pune'}
{'_id': '1006', 'name': 'Rasajna', 'age': 26, 'city': 'Chennai'}
{'_id': '1001', 'name': 'Ram', 'age': '26', 'city': 'Hyderabad'}
{'_id': '1002', 'name': 'Rahim', 'age': '27', 'city': 'Bangalore'}
{'_id': '1003', 'name': 'Robert', 'age': '28', 'city': 'Mumbai'}