Python - NoSQL 数据库
随着越来越多的数据以非结构化或半结构化形式提供,通过 NoSql 数据库管理这些数据的需求也随之增加。Python 还可以以与关系数据库交互类似的方式与 NoSQL 数据库交互。在本章中,我们将使用 Python 与 MongoDB 作为 NoSQL 数据库进行交互。 如果您是 MongoDB 新手,您可以在我们的教程此处中学习它。>
为了连接到 MongoDB,Python 使用一个名为 pymongo 的库。您可以使用 Anaconda 环境中的以下命令将此库添加到您的 Python 环境中。
conda install pymongo
此库使 Python 能够使用数据库客户端连接到 MOngoDB。连接后,我们选择要用于各种操作的数据库名称。
插入数据
要将数据插入 MongoDB,我们使用数据库环境中可用的 insert() 方法。首先,我们使用下面显示的 Python 代码连接到数据库,然后我们 以一系列键值对的形式提供文档详细信息。
# 导入 Python 库 from pymongo import MongoClient from pprint import pprint # 选择合适的客户端 client = MongoClient() # 连接到测试数据库 db=client.test # 使用员工集合 employee = db.employee employee_details = { 'Name': 'Raj Kumar', 'Address': 'Sears Streer, NZ', 'Age': '42' } # 使用插入方法 result = employee.insert_one(employee_details) # 查询插入的文档。 Queryresult = employee.find_one({'Age': '42'}) pprint(Queryresult)
当我们执行上述代码时,它会产生以下结果。
{u'Address': u'Sears Streer, NZ', u'Age': u'42', u'Name': u'Raj Kumar', u'_id': ObjectId('5adc5a9f84e7cd3940399f93')}
更新数据
更新现有 MongoDB 数据与插入类似。我们使用 mongoDB 原生的 update() 方法。在下面的代码中,我们用新的键值对替换现有 记录。请注意我们如何使用条件标准来决定要更新哪条记录。
# 导入 python 库 from pymongo import MongoClient from pprint import pprint # 选择适当的客户端 client = MongoClient() # 连接到数据库 db=client.test employee = db.employee # 使用条件选择记录 # 并使用更新方法 db.employee.update_one( {"Age":'42'}, { "$set": { "Name":"Srinidhi", "Age":'35', "Address":"New Omsk, WC" } } ) Queryresult = employee.find_one({'Age':'35'}) pprint(Queryresult)
当我们执行上述代码时,它会产生以下结果。
{u'Address': u'New Omsk, WC', u'Age': u'35', u'Name': u'Srinidhi', u'_id': ObjectId('5adc5a9f84e7cd3940399f93')}
删除数据
使用 delete 方法删除记录也很简单。这里我们还提到了用于选择要删除的记录的条件。
# 导入 Python 库 from pymongo import MongoClient from pprint import pprint # 选择适当的客户端 client = MongoClient() # 连接到数据库 db=client.test employee = db.employee # 使用条件选择记录 # 并使用删除方法 db.employee.delete_one({"Age":'35'}) Queryresult = employee.find_one({'Age':'35'}) pprint(Queryresult)
当我们执行上述代码时,它会产生以下结果。
None
因此,我们看到数据库中不再存在该特定记录。