Python MongoDB - 查找
您可以使用 find() 方法从 MongoDB 读取/检索存储的文档。此方法以非结构化方式检索并显示 MongoDB 中的所有文档。
语法
以下是 find() 方法的语法。
>db.COLLECTION_NAME.find()
示例
假设我们使用以下查询将 3 个文档插入到名为 testDB 的集合中的名为 sample 的数据库中 −
> 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)
pymongo 的 find_One() 方法用于根据您的查询检索单个文档,如果没有匹配项,此方法将不返回任何内容,如果您不使用任何查询,它将返回集合中的第一个文档。
当您需要仅检索结果中的一个文档时,或者如果您确定查询仅返回一个文档,此方法就很方便。
示例
以下是 Python 示例检索集合中的第一个文档 −
from pymongo import MongoClient #创建 pymongo 客户端 client = MongoClient('localhost', 27017) #获取数据库实例 db = client['mydatabase'] #创建集合 coll = db['example'] #将文档插入集合 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) #使用 find_one() 方法检索第一条记录 print("First record of the collection: ") print(coll.find_one()) #使用 find_one() 方法检索值为 103 的记录 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 的 find() 方法。如果未传递任何查询,则该方法将返回集合中的所有文档;如果已将查询传递给此方法,则该方法将返回所有匹配的文档。
示例
#获取数据库实例 db = client['myDB'] #创建集合 coll = db['example'] #将文档插入集合 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 ......") #使用 find() 方法检索所有记录 print("Records of the collection: ") for doc1 in coll.find(): print(doc1) #使用 find() 方法检索年龄大于 26 的记录 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'}