Python MongoDB-찾기

MongoDB에서 저장된 문서를 읽고 검색 할 수 있습니다. find()방법. 이 메서드는 MongoDB의 모든 문서를 구조화되지 않은 방식으로 검색하고 표시합니다.

통사론

다음은 find() 방법.

>db.CollectionName.find()

다음 쿼리를 사용하여 sample이라는 컬렉션의 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)

다음과 같이 find () 메소드를 사용하여 삽입 된 문서를 검색 할 수 있습니다.

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

findOne () 메소드를 사용하여 컬렉션의 첫 번째 문서를 검색 할 수도 있습니다.

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

Python을 사용하여 데이터 검색 (찾기)

그만큼 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()pymongo의 방법. 쿼리를 전달하지 않은 경우 컬렉션의 모든 문서를 반환하고이 메서드에 쿼리를 전달한 경우 일치하는 모든 문서를 반환합니다.

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