Python数据科学教程:作为NoSQL数据库与MongoDB进行交互

2018-09-3009:07:37后端程序开发Comments2,488 views字数 1940阅读模式

越来越多的数据以非结构化或半结构化的方式来提供,需要通过NoSql数据库来管理它们。 Python也可以以与关系数据库交互的相似方式与NoSQL数据库进行交互。 在本章中,我们将使用python作为NoSQL数据库与MongoDB进行交互。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/6038.html

要连接到MongoDB,python使用一个名为pymongo的库。可以使用Anaconda环境中的以下命令将此库添加到您的python环境。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/6038.html

conda install pymongo
Shell

这个库允许python使用数据库客户端连接到MOngoDB。 一旦连接,我们选择要用于各种操作的数据库名称。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/6038.html

插入数据

要将数据插入到MongoDB中,使用数据库环境中可用的insert()方法。 首先使用下面显示的Python代码连接到数据库,然后以一系列键值对的形式提供文档详细信息。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/6038.html

# Import the python libraries
from pymongo import MongoClient
from pprint import pprint

# Choose the appropriate client
client = MongoClient()

# Connect to the test db 
db=client.test

# Use the employee collection
employee = db.employee
employee_details = {
    'Name': 'Raj Kumar',
    'Address': 'Sears Streer, NZ',
    'Age': '42'
}

# Use the insert method
result = employee.insert_one(employee_details)

# Query for the inserted document.
Queryresult = employee.find_one({'Age': '42'})
print(Queryresult)
Python

执行上面示例代码,得到以下结果 -文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/6038.html

{u'Address': u'Sears Streer, NZ',
 u'Age': u'42',
 u'Name': u'Raj Kumar',
 u'_id': ObjectId('5adc5a9f84e7cd3940399f93')}
Shell

更新数据

更新现有的MongoDB数据与插入类似。 使用mongoDB原生的update()方法。 在下面的代码中,使用新的键值对替换了现有的记录。 请注意:这里可通过使用条件标准来决定更新哪条记录。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/6038.html

# Import the python libraries
from pymongo import MongoClient
from pprint import pprint

# Choose the appropriate client
client = MongoClient()

# Connect to db
db=client.test
employee = db.employee

# Use the condition to choose the record
# and use the update method
db.employee.update_one(
        {"Age":'42'},
        {
        "$set": {
            "Name":"Srinidhi",
            "Age":'35',
            "Address":"New Omsk, WC"
        }
        }
    )

Queryresult = employee.find_one({'Age':'35'})

print(Queryresult)
Python

当执行上面的代码时,它会产生以下结果。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/6038.html

{u'Address': u'New Omsk, WC',
 u'Age': u'35',
 u'Name': u'Srinidhi',
 u'_id': ObjectId('5adc5a9f84e7cd3940399f93')}
Shell

删除数据

使用delete方法的地方删除记录也很简单。 这里还提到用于选择要删除的记录的条件。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/6038.html

# Import the python libraries
from pymongo import MongoClient
from pprint import pprint

# Choose the appropriate client
client = MongoClient()

# Connect to db
db=client.test
employee = db.employee

# Use the condition to choose the record
# and use the delete method
db.employee.delete_one({"Age":'35'})

Queryresult = employee.find_one({'Age':'35'})

print(Queryresult)
Python

执行上面示例代码,得到以下结果 -文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/6038.html

None
Shell

所以看到特定的记录不再存在于db中。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/6038.html

  • 本站内容整理自互联网,仅提供信息存储空间服务,以方便学习之用。如对文章、图片、字体等版权有疑问,请在下方留言,管理员看到后,将第一时间进行处理。
  • 转载请务必保留本文链接:https://www.cainiaoxueyuan.com/bc/6038.html

Comment

匿名网友 填写信息

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:

确定