Python操作MongoDB数据库(简明版)
除了通过启动 mongo 进程进如 Shell 环境访问数据库外,MongoDB 还提供了其他基于编程语言的访问数据库方法。MongoDB 官方提供了 Java 和 Python 语言的驱动包,利用这些驱动包可使用多种编程方法来连接并操作 MongoDB 数据库。
使用 Java 语言的读者请转到:Java 操作 MongoDB 数据库
通过 Python 3.x 访问 MongoDB,需要借助开源驱动库 pymongo(由 MongoDB 官方提供)。pymongo 驱动程序可以直接连接 MongdoDB 数据库,然后对数据库进行操作。
安装 pymongo 驱动可使用 pip 方式:
pip install pymongo
建立连接
1) 模块引用
Python 驱动库连接 MongoDB 比较简单,而且同时支持自动的故障修复,即连接时出现故障会自动重新连接。
在 Python 脚本中连接 MongoDB 首先要导入需要的 pymongo 库:
import pymongo
然后使用 MongoClient 对象创建与数据库服务器的连接:
Client = MongoClient(host= '10.90.9.101', port=27017)
使用上面的代码片段,通过指定 host 和 port 连接到我们在《将MongoDB部署到分布式集群(实操)》一节中部署的集群中的路由服务器。
当然也可连接具体的 mongod 服务器或副本集:
Client=MongoClient(host='10.90.9.102',port=27018) Client=MongoClient(host='10.90.9.101: 27018, 10.90.9.102: 27018,10.90.9.103: 27018')
2) 访问数据库
创建 MongoClient 实例后,就可以访问服务器中的任何数据。如果要访问一个数据库,可以将其当作属性一样进行访问:
db = client.myDB
也可以使用函数方式访问,如果不存在数据库,则系统会自动创建数据库:
db = conn.get_database("myDB")
集合操作
1) 插入文档
在数据库中存储数据时,首先指定使用的集合,然后使用集合的 insert_one() 方法插入文档,如下代码定义了 post_data 的 JSON 文档:
coll = db.get_collection("myCollection") post_data = { '_id' : '10' 'item' : 'book1', 'qty' : 18 } result = coll.insert_one(post_data)
可以使用 insert_one() 同时插入多个文档,将多个文档添加到数据库中,还可以使用方法 insert_many()。此方法的参数可以是如下的 list 列表:
post_1 = { '_id' : '11', 'item1' : 'book1', 'qty' : 18 } post_2 = { '_id' : '12', 'item1' : 'book1', 'qty' : 18 } post_3 = { '_id' : '13', 'item1' : 'book1', 'qty' : 18 } new result = coll.insert_many([post_1, post_2, post_3])
2) 检索文档
检索文档可以使用 find_one() 方法,例如,可使用如下语句找到 item 为 book 的记录:
find_post = coll.find_one({'item' : 'book'})
如果需要查询多条记录,则可以使用 find() 方法,代码如下:
find_posts = coll.find({'item' : 'book1'})
3) 更新数据
可以使用 update() 方法更新数据,只需指定更新的条件和更新后的数据即可:
condition = {'item' : 'book'} pty{'$set' : {'pty' : 22}} result = col.update(condition, pty)
4) 删除数据
删除操作比较简单,直接调用 remove() 方法指定删除的条件即可,符合条件的所有数据均会被删除,代码如下:
result = coll.remove({'item' : 'book'})
另外,还可以使用 delete_one() 和 delete_many() 方法,示例如下:
result = coll.delete_one({'item' : 'book'}) resuIt = collection.delete_many({'item' : book1})
发表评论