अजगर MongoDB - सीमा
किसी संग्रह की सामग्री को पुनर्प्राप्त करते समय आप परिणाम () विधि का उपयोग करके दस्तावेजों की संख्या को सीमित कर सकते हैं। यह विधि कई मानों को स्वीकार करती है जो परिणाम में आपके वांछित दस्तावेजों की संख्या का प्रतिनिधित्व करते हैं।
वाक्य - विन्यास
निम्नलिखित सीमा () विधि का वाक्य विन्यास है -
>db.COLLECTION_NAME.find().limit(NUMBER)
उदाहरण
मान लें कि हमने एक संग्रह बनाया है और उसमें 5 दस्तावेज़ डाले हैं जैसा कि नीचे दिखाया गया है -
> use testDB
switched to db testDB
> db.createCollection("sample")
{ "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" : [ ]
})
निम्नलिखित पंक्ति संग्रह के पहले 3 दस्तावेजों को पुनः प्राप्त करती है।
> db.sample.find().limit(3)
{ "_id" : "1001", "name" : "Ram", "age" : "26", "city" : "Hyderabad" }
{ "_id" : "1002", "name" : "Rahim", "age" : 27, "city" : "Bangalore" }
{ "_id" : "1003", "name" : "Robert", "age" : 28, "city" : "Mumbai" }
पायथन का उपयोग करके दस्तावेजों को सीमित करना
एक प्रश्न के परिणामों को प्रतिबंधित करने के लिए एक विशेष संख्या में दस्तावेजों के लिए pymongo प्रदान करता है limit()तरीका। इस पद्धति के लिए आपको परिणाम में आवश्यक दस्तावेजों की संख्या का प्रतिनिधित्व करते हुए एक संख्या मान पास करना होगा।
उदाहरण
निम्नलिखित उदाहरण एक संग्रह में पहले तीन दस्तावेजों को पुनः प्राप्त करता है।
from pymongo import MongoClient
#Creating a pymongo client
client = MongoClient('localhost', 27017)
#Getting the database instance
db = client['l']
#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("First 3 documents in the collection: ")
for doc1 in coll.find().limit(3):
print(doc1)
उत्पादन
Data inserted ......
First 3 documents in the collection:
{'_id': '1001', 'name': 'Ram', 'age': '26', 'city': 'Hyderabad'}
{'_id': '1002', 'name': 'Rahim', 'age': '27', 'city': 'Bangalore'}
{'_id': '1003', 'name': 'Robert', 'age': '28', 'city': 'Mumbai'}