Python MongoDB - Bul

Depolanan belgeleri MongoDB'den okuyabilir / alabilirsiniz. find()yöntem. Bu yöntem, MongoDB'deki tüm belgeleri yapılandırılmamış bir şekilde alır ve görüntüler.

Sözdizimi

Aşağıdaki sözdizimi find() yöntem.

>db.COLLECTION_NAME.find()

Misal

Aşağıdaki sorguları kullanarak örnek adlı bir koleksiyona testDB adlı bir veritabanına 3 belge eklediğimizi varsayalım -

> 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)

Eklenen belgeleri aşağıdaki gibi find () yöntemini kullanarak alabilirsiniz:

> 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" }
>

Ayrıca findOne () yöntemini kullanarak koleksiyondaki ilk belgeyi şu şekilde alabilirsiniz:

> db.sample.findOne()
{ "_id" : "1001", "name" : "Ram", "age" : "26", "city" : "Hyderabad" }

Python Kullanarak Veri Alma (bul)

find_One() Pymongo yöntemi, sorgunuza bağlı olarak tek bir belgeyi almak için kullanılır, eşleşme olmaması durumunda bu yöntem hiçbir şey döndürmez ve herhangi bir sorgu kullanmazsanız koleksiyonun ilk belgesini döndürür.

Bu yöntem, bir sonucun yalnızca bir belgesini almanız gerektiğinde veya sorgunuzun yalnızca bir belge döndürdüğünden eminseniz kullanışlı olur.

Misal

Aşağıdaki python örneği, bir koleksiyonun ilk belgesini alır -

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"}))

Çıktı

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'}

Tek bir sorguda birden çok belge almak için (tek arama veya bulma yöntemi), find()pymongo yöntemi. Herhangi bir sorgu geçmediyse, bu bir koleksiyonun tüm belgelerini döndürür ve bu yönteme bir sorgu ilettiyseniz, eşleşen tüm belgeleri döndürür.

Misal

#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)

Çıktı

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'}