पायथन MongoDB - खोजें
आप MongoDB से संग्रहीत दस्तावेजों को पढ़ / प्राप्त कर सकते हैं find()तरीका। यह विधि गैर-संरचित तरीके से MongoDB में सभी दस्तावेजों को पुनर्प्राप्त और प्रदर्शित करती है।
वाक्य - विन्यास
निम्नलिखित का सिंटैक्स है find() तरीका।
>db.COLLECTION_NAME.find()
उदाहरण
मान लें कि हमने निम्नलिखित प्रश्नों का उपयोग करते हुए नमूने नाम के एक संग्रह में testDB नामक डेटाबेस में 3 दस्तावेज़ सम्मिलित किए हैं -
> use testDB
> db.createCollection("sample")
> 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" }
]
> db.sample.insert(data)
आप खोजे गए () विधि का उपयोग करके सम्मिलित किए गए दस्तावेजों को पुनः प्राप्त कर सकते हैं -
> use testDB
switched to db testDB
> db.sample.find()
{ "_id" : "1001", "name" : "Ram", "age" : "26", "city" : "Hyderabad" }
{ "_id" : "1002", "name" : "Rahim", "age" : 27, "city" : "Bangalore" }
{ "_id" : "1003", "name" : "Robert", "age" : 28, "city" : "Mumbai" }
>
आप संग्रह में पहला दस्तावेज़ पुनः प्राप्त कर सकते हैं जैसे कि खोज () विधि का उपयोग करके -
> db.sample.findOne()
{ "_id" : "1001", "name" : "Ram", "age" : "26", "city" : "Hyderabad" }
डेटा पुनर्प्राप्त करना (ढूंढें) पायथन का उपयोग करना
find_One() pymongo की विधि का उपयोग आपकी क्वेरी के आधार पर एक एकल दस्तावेज़ को पुनः प्राप्त करने के लिए किया जाता है, कोई भी मैच के मामले में यह विधि कुछ भी नहीं लौटाती है और यदि आप किसी भी क्वेरी का उपयोग नहीं करते हैं तो यह संग्रह का पहला दस्तावेज़ लौटाता है।
जब भी आपको किसी परिणाम के केवल एक दस्तावेज़ को प्राप्त करने की आवश्यकता होती है, तो यह विधि काम आती है, या यदि आप सुनिश्चित हैं कि आपकी क्वेरी केवल एक दस्तावेज़ लौटाती है।
उदाहरण
अजगर उदाहरण के बाद एक संग्रह का पहला दस्तावेज प्राप्त होता है -
from pymongo import MongoClient
#Creating a pymongo client
client = MongoClient('localhost', 27017)
#Getting the database instance
db = client['mydatabase']
#Creating a collection
coll = db['example']
#Inserting document into a collection
data = [
{"_id": "101", "name": "Ram", "age": "26", "city": "Hyderabad"},
{"_id": "102", "name": "Rahim", "age": "27", "city": "Bangalore"},
{"_id": "103", "name": "Robert", "age": "28", "city": "Mumbai"}
]
res = coll.insert_many(data)
print("Data inserted ......")
print(res.inserted_ids)
#Retrieving the first record using the find_one() method
print("First record of the collection: ")
print(coll.find_one())
#Retrieving a record with is 103 using the find_one() method
print("Record whose id is 103: ")
print(coll.find_one({"_id": "103"}))
उत्पादन
Data inserted ......
['101', '102', '103']
First record of the collection:
{'_id': '101', 'name': 'Ram', 'age': '26', 'city': 'Hyderabad'}
Record whose id is 103:
{'_id': '103', 'name': 'Robert', 'age': '28', 'city': 'Mumbai'}
एक ही क्वेरी में कई दस्तावेज़ प्राप्त करने के लिए (एकल कॉल ऑड फ़ाइंड विधि), आप इसका उपयोग कर सकते हैं find()पाइमोन्गो की विधि। यदि आपने कोई क्वेरी पारित नहीं की है, तो यह एक संग्रह के सभी दस्तावेजों को लौटाता है और, यदि आपने इस पद्धति से कोई क्वेरी पारित की है, तो यह सभी मिलान दस्तावेजों को लौटाता है।
उदाहरण
#Getting the database instance
db = client['myDB']
#Creating a collection
coll = db['example']
#Inserting document into a collection
data = [
{"_id": "101", "name": "Ram", "age": "26", "city": "Hyderabad"},
{"_id": "102", "name": "Rahim", "age": "27", "city": "Bangalore"},
{"_id": "103", "name": "Robert", "age": "28", "city": "Mumbai"}
]
res = coll.insert_many(data)
print("Data inserted ......")
#Retrieving all the records using the find() method
print("Records of the collection: ")
for doc1 in coll.find():
print(doc1)
#Retrieving records with age greater than 26 using the find() method
print("Record whose age is more than 26: ")
for doc2 in coll.find({"age":{"$gt":"26"}}):
print(doc2)
उत्पादन
Data inserted ......
Records of the collection:
{'_id': '101', 'name': 'Ram', 'age': '26', 'city': 'Hyderabad'}
{'_id': '102', 'name': 'Rahim', 'age': '27', 'city': 'Bangalore'}
{'_id': '103', 'name': 'Robert', 'age': '28', 'city': 'Mumbai'}
Record whose age is more than 26:
{'_id': '102', 'name': 'Rahim', 'age': '27', 'city': 'Bangalore'}
{'_id': '103', 'name': 'Robert', 'age': '28', 'city': 'Mumbai'}