首页 > 数据库 >10 Python进阶:MongoDB

10 Python进阶:MongoDB

时间:2024-04-07 11:32:44浏览次数:40  
标签:10 进阶 Python MongoDB 数据库 collection client 文档 pymongo

MongoDb介绍

在这里插入图片描述

MongoDB是一个基于分布式架构的文档数据库,它使用JSON样式的数据存储,支持动态查询,完全索引。MongoDB是NoSQL数据库的一种,主要用于处理大型、半结构化或无结构化的数据。以下是MongoDB数据库的一些关键特点和优势:

  1. 分布式架构: MongoDB可以运行在多个服务器上,以实现高可用性和可伸缩性,允许数据存储在集群中的不同节点上。

  2. 文档数据库: MongoDB使用类似JSON格式的BSON(Binary JSON)来存储数据,每个文档都是一个数据记录,这些文档可以包含不同结构和类型的数据。

  3. 动态查询: MongoDB支持丰富的查询操作,它使用内置的聚合框架来实现复杂的数据分析和数据处理。

  4. 完全索引: MongoDB支持创建多种类型的索引,包括单字段、复合字段和地理空间索引,以提高查询性能和灵活性。

  5. 分片和复制: MongoDB可以通过分片将数据水平划分为多个部分,同时还支持数据复制来提供数据可靠性和可用性。

  6. 丰富的功能: MongoDB提供了丰富的功能,包括灵活的数据模型、强大的聚合框架、自动分片和负载均衡等。

MongoDB是一个灵活、高性能、可扩展的数据库系统,特别适合用于处理大规模、半结构化或无结构化的数据,例如Web应用程序、日志存储、内容管理,以及实时分析等场景。

PyMongo 安装和测试

PyMongo是Python与MongoDB数据库交互的官方驱动程序,可以让Python开发人员方便地与MongoDB数据库进行连接、查询和操作。下面是关于PyMongo的介绍以及如何安装和测试PyMongo的简单示例:
在这里插入图片描述

PyMongo介绍:

  • PyMongo是MongoDB官方提供的Python驱动程序,提供了高效的API来与MongoDB进行交互。
  • PyMongo支持对MongoDB数据库进行连接、插入数据、查询数据、更新数据、删除数据等操作。
  • PyMongo贴合Python开发者的习惯和使用方式,使得在Python应用程序中操作MongoDB更加便捷。

安装PyMongo:

你可以使用pip命令来安装PyMongo,运行以下命令:

pip install pymongo

测试PyMongo:

以下是一个简单的PyMongo测试示例,实现连接到MongoDB数据库、插入数据、查询数据的功能:

import pymongo


运行上述代码,导入不报错即可。

创建数据库

在MongoDB中,可以通过连接到数据库并查询数据库的方式来判断数据库是否已存在,如果不存在则创建数据库。下面是一个使用PyMongo实现这一功能的示例代码:

import pymongo

# 连接到本地MongoDB数据库
client = pymongo.MongoClient("mongodb://localhost:27017/")

# 列出所有数据库
database_list = client.list_database_names()

# 要创建的数据库名称
database_name = "mydatabase"

# 判断数据库是否已存在
if database_name in database_list:
    print(f"数据库 {database_name} 已经存在。")
else:
    # 创建数据库
    db = client[database_name]
    print(f"数据库 {database_name} 创建成功。")

# 重新列出所有数据库,检查是否成功创建
print(client.list_database_names())

运行以上代码后,它会连接到本地MongoDB数据库,列出所有数据库的名称,然后判断要创建的数据库是否已存在。如果数据库已存在,则输出提示信息;如果数据库不存在,则创建该数据库并输出成功创建的提示信息,并重新列出所有数据库,以确认新数据库是否已成功创建。

通过这种方式,你可以在PyMongo中判断数据库是否已存在,如果不存在则创建数据库。

创建集合

在MongoDB中,可以通过集合是否存在来判断数据库中的集合是否已存在,如果不存在则创建新集合。下面是一个使用PyMongo实现这一功能的示例代码:

import pymongo

# 连接到本地MongoDB数据库
client = pymongo.MongoClient("mongodb://localhost:27017/")

# 选择要操作的数据库
db = client["mydatabase"] 

# 要创建的集合名称
collection_name = "customers"

# 列出所有集合
collection_list = db.list_collection_names()

# 判断集合是否已存在
if collection_name in collection_list:
    print(f"集合 {collection_name} 已经存在。")
else:
    # 创建集合
    db.create_collection(collection_name)
    print(f"集合 {collection_name} 创建成功。")

# 重新列出所有集合,检查是否成功创建
print(db.list_collection_names())

运行以上代码后,它会连接到本地MongoDB数据库,并选择操作名为"mydatabase"的数据库。然后,它会列出数据库中的所有集合名称,判断要创建的集合是否已存在。如果集合已存在,则输出提示信息;如果集合不存在,则创建该集合并输出成功创建的提示信息,并重新列出所有集合名称,以确认新集合是否已成功创建。

在MongoDB中使用PyMongo,可以通过不同的方式向集合中插入文档(数据)。以下是几种常见的插入文档的方式:

1. 插入单个文档:

你可以使用insert_one()方法向集合中插入单个文档。示例代码如下:

import pymongo

# 连接到本地MongoDB数据库
client = pymongo.MongoClient("mongodb://localhost:27017/")
db = client["mydatabase"]
collection = db["mycollection"]

data = { "name": "Alice", "age": 30, "city": "Shanghai" }
insert_result = collection.insert_one(data)
print("Inserted data with ID:", insert_result.inserted_id)

2. 插入多个文档:

使用insert_many()方法可以向集合中插入多个文档。示例代码如下:

import pymongo

# 连接到本地MongoDB数据库
client = pymongo.MongoClient("mongodb://localhost:27017/")
db = client["mydatabase"]
collection = db["mycollection"]

data_list = [
    { "name": "Bob", "age": 25, "city": "Beijing" },
    { "name": "Cathy", "age": 35, "city": "Guangzhou" }
]

insert_result = collection.insert_many(data_list)
print("Inserted data with IDs:", insert_result.inserted_ids)

3. 使用save()方法插入文档:

你也可以使用save()方法向集合中插入文档,如果文档存在则更新,不存在则插入。示例代码如下:

import pymongo

# 连接到本地MongoDB数据库
client = pymongo.MongoClient("mongodb://localhost:27017/")
db = client["mydatabase"]
collection = db["mycollection"]

data = { "name": "David", "age": 40, "city": "Chengdu" }
insert_result = collection.save(data)
print("Inserted or updated data with ID:", data["_id"])

这些是向MongoDB集合中插入文档的几种常见方法。根据具体需求不同,选择适合的方法来插入数据。

在MongoDB中使用PyMongo,你可以通过不同的方法删除集合中的文档。以下是几种常见的删除文档的方式:

1. 删除单个文档:

你可以使用delete_one()方法删除符合特定条件的单个文档。示例代码如下:

import pymongo

# 连接到本地MongoDB数据库
client = pymongo.MongoClient("mongodb://localhost:27017/")
db = client["mydatabase"]
collection = db["mycollection"]

query = { "name": "Alice" }
delete_result = collection.delete_one(query)
print(delete_result.deleted_count, "document deleted.")

2. 删除多个文档:

使用delete_many()方法可以删除符合特定条件的多个文档。示例代码如下:

import pymongo

# 连接到本地MongoDB数据库
client = pymongo.MongoClient("mongodb://localhost:27017/")
db = client["mydatabase"]
collection = db["mycollection"]

query = { "age": { "$lt": 30 } }
delete_result = collection.delete_many(query)
print(delete_result.deleted_count, "documents deleted.")

3. 删除集合中所有文档:

如果你想一次性清空整个集合,可以使用delete_many({})方法删除集合中的所有文档。示例代码如下:

import pymongo

# 连接到本地MongoDB数据库
client = pymongo.MongoClient("mongodb://localhost:27017/")
db = client["mydatabase"]
collection = db["mycollection"]

delete_result = collection.delete_many({})
print(delete_result.deleted_count, "documents deleted.")

这是向MongoDB集合中删除文档的几种常见方法。

在MongoDB中使用PyMongo,你可以通过不同的方法修改集合中的文档。以下是几种常见的修改文档的方式:

1. 更新单个文档:

你可以使用update_one()方法来更新符合特定条件的单个文档。示例代码如下:

import pymongo

# 连接到本地MongoDB数据库
client = pymongo.MongoClient("mongodb://localhost:27017/")
db = client["mydatabase"]
collection = db["mycollection"]

filter_query = { "name": "Alice" }
update_query = { "$set": { "age": 31 } }

update_result = collection.update_one(filter_query, update_query)
print(update_result.modified_count, "document updated.")

2. 更新多个文档:

使用update_many()方法可以更新符合特定条件的多个文档。示例代码如下:

import pymongo

# 连接到本地MongoDB数据库
client = pymongo.MongoClient("mongodb://localhost:27017/")
db = client["mydatabase"]
collection = db["mycollection"]

filter_query = { "city": "Shanghai" }
update_query = { "$set": { "city": "Beijing" } }

update_result = collection.update_many(filter_query, update_query)
print(update_result.modified_count, "documents updated.")

3. 替换文档:

使用replace_one()方法可以替换符合特定条件的单个文档。示例代码如下:

import pymongo

# 连接到本地MongoDB数据库
client = pymongo.MongoClient("mongodb://localhost:27017/")
db = client["mydatabase"]
collection = db["mycollection"]

filter_query = { "name": "Bob" }
replacement_doc = { "name": "Bobby", "age": 26, "city": "Hangzhou" }

replace_result = collection.replace_one(filter_query, replacement_doc)
print(replace_result.modified_count, "document replaced.")

这些是在MongoDB中修改文档的几种常见方法。根据具体需求,选择适合的方法来修改数据。

在MongoDB中使用PyMongo,你可以通过不同的方法查询集合中的文档。以下是几种常见的查询文档的方式:

1. 查询单个文档:

使用find_one()方法可以查询符合特定条件的单个文档。示例代码如下:

import pymongo

# 连接到本地MongoDB数据库
client = pymongo.MongoClient("mongodb://localhost:27017/")
db = client["mydatabase"]
collection = db["mycollection"]

query = { "name": "Alice" }

result = collection.find_one(query)
print(result)

2. 查询多个文档:

使用find()方法可以查询符合特定条件的多个文档。示例代码如下:

import pymongo

# 连接到本地MongoDB数据库
client = pymongo.MongoClient("mongodb://localhost:27017/")
db = client["mydatabase"]
collection = db["mycollection"]

query = { "age": { "$gt": 25 } }

results = collection.find(query)
for result in results:
    print(result)

3. 简单查询:

你还可以进行更简单的查询,例如查询所有文档、对查询结果进行排序等操作。示例代码如下:

import pymongo

# 连接到本地MongoDB数据库
client = pymongo.MongoClient("mongodb://localhost:27017/")
db = client["mydatabase"]
collection = db["mycollection"]

# 查询所有文档
results = collection.find()
for result in results:
    print(result)

# 查询所有文档并按年龄降序排序
results = collection.find().sort("age", pymongo.DESCENDING)
for result in results:
    print(result)

这些是在MongoDB中查询文档的几种常见方法。根据具体需求,选择适合的方法来查询数据。

排序

在MongoDB中使用PyMongo,你可以使用sort()方法对查询结果进行排序。以下是一些常见的排序示例:

1. 升序排序:

要对特定字段进行升序排序,可以使用pymongo.ASCENDING或者1表示升序。示例代码如下:

import pymongo

# 连接到本地MongoDB数据库
client = pymongo.MongoClient("mongodb://localhost:27017/")
db = client["mydatabase"]
collection = db["mycollection"]

# 对age字段进行升序排序
results = collection.find().sort("age", pymongo.ASCENDING)
for result in results:
    print(result)

2. 降序排序:

要对特定字段进行降序排序,可以使用pymongo.DESCENDING或者-1表示降序。示例代码如下:

import pymongo

# 连接到本地MongoDB数据库
client = pymongo.MongoClient("mongodb://localhost:27017/")
db = client["mydatabase"]
collection = db["mycollection"]

# 对age字段进行降序排序
results = collection.find().sort("age", pymongo.DESCENDING)
for result in results:
    print(result)

3. 多重排序:

如果需要按照多个字段进行排序,可以在sort()方法中指定多个字段和对应的排序方式。示例代码如下:

import pymongo

# 连接到本地MongoDB数据库
client = pymongo.MongoClient("mongodb://localhost:27017/")
db = client["mydatabase"]
collection = db["mycollection"]

# 先按age字段降序排序,再按name字段升序排序
results = collection.find().sort([("age", pymongo.DESCENDING), ("name", pymongo.ASCENDING)])
for result in results:
    print(result)

以上是对MongoDB查询结果进行排序的示例代码。根据具体需求,在查询时添加适当的排序操作即可

关注我,不迷路,共学习,同进步

关注我,不迷路,共学习,同进步

在这里插入图片描述

标签:10,进阶,Python,MongoDB,数据库,collection,client,文档,pymongo
From: https://blog.csdn.net/sixpp/article/details/137456183

相关文章

  • 基于R、Python的Copula变量相关性分析及AI大模型应用
    在工程、水文和金融等各学科的研究中,总是会遇到很多变量,研究这些相互纠缠的变量间的相关关系是各学科的研究的重点。虽然皮尔逊相关、秩相关等相关系数提供了变量间相关关系的粗略结果,但这些系数都存在着无法克服的困难。例如,皮尔逊相关系数只能反映变量间的线性相关,而秩相关则......
  • solidity语言语法补充(进阶版)
    函数修改器:在Solidity中,函数修改器(FunctionModifiers)是一种用于修改函数行为的特殊类型。它可以在函数执行前、执行后或者在函数执行期间对函数的行为进行修改或增加额外的逻辑。函数修改器通常用于提高代码的重用性、简化代码结构,并确保一致的行为。1.定义函数修改器函数......
  • 【MATLAB源码-第10期】基于matlab的pi/4DQPSK,π/4DQPSK的误码率BER理论和实际对比仿
    1、算法描述蓝牙是一种被广泛应用的无线通信标准,工作在2.4GHz-2.4835GHz频段范围,所用的调制方式有:GFSK,PI/4-DQPSK。北美第二代数字蜂窝移动通信系统D-AMPS和日本的JDC蜂窝系统均采用PI/4-DQPSK,欧洲的GSM系统采用GMSK。PI/4-DQPSK与GMSK等恒包络调制技术相比有更高的频谱利......
  • 2024-04-07 记录win10批量修改文件后缀的方法 ==》ren *.exe *.zip
    使用ren命令,注意是win10系统在需要修改后缀名的文件夹路径打开cmd,如: 比如我想把这些exe文件修改为zip后缀,现在路径打开cmd,然后输入命令:ren*.exe*.zip注意该命令会把当前文件夹内所有的.exe后缀批量改成.zip,如果是重要文件,请先备份,以防丢失。 以上没有报错表示成功,如......
  • 洛谷题单指南-数学基础问题-P1100 高低位交换
    原题链接:https://www.luogu.com.cn/problem/P1100题意解读:将32位二进制数的高低16位交换位置。解题思路:给定无符号整数a,假设二进制高16为h,低16位为l,即a表示为hl,a>>16得到0h,a<<16得到l0,两者相加即得到lh,交换完毕。需要注意的是,无符号整数的表示是unsignedint,如果是int,......
  • python接口自动化实现--基于logging库的日志打印
    1、日志的级别                debug:调试级别,打印非常详细的日志信息,通常用于代码调试        info:信息级别,打印一般的日志信息,突出强调程序的运行过程        warming:警告级别,打印警告信息,表明可能出现潜在的错误        error......
  • 超级好用的 IEC104 主站/客户端模拟器
    目录超级好用的IEC104主站/客户端模拟器主要功能软件截图超级好用的IEC104主站/客户端模拟器官网下载地址:http://www.redisant.cn/iec104client主要功能同时模拟多个主站/客户端。在单个连接中模拟多个站(公共地址)。完整的信息对象解析,通过表格查看信息对象的所有属性。......
  • (免费赠源码)计算机毕设题目:基于微信小程序的旅游服务系统 77397(开题答辩+程序定制+全套
    springboot旅游服务系统小程序摘 要随着我国经济迅速发展,人们对手机的需求越来越大,各种手机软件也都在被广泛应用,但是对于手机进行数据信息管理,对于手机的各种软件也是备受用户的喜爱,旅游服务系统小程序管理系统被用户普遍使用,为方便用户能够可以随时进行旅游服务系统小......
  • Java;springboot;MYSQL+基于springBoot的大学生就业管理85553(免费领源码)计算机毕业设计
    大学生就业管理系统的设计与实现摘 要信息化社会内需要与之针对性的信息获取途径,但是途径的扩展基本上为人们所努力的方向,由于站在的角度存在偏差,人们经常能够获得不同类型信息,这也是技术最为难以攻克的课题。针对学生就业管理等问题,对学生就业管理进行研究分析,然后开发设......
  • Java/Mysql数据库+django学生就业管理系统 24237(免费领源码)计算机毕业设计项目推荐上
    学生就业管理系统摘 要随着社会的快速发展和人们生活水平的不断提高,旅游已逐渐成为人们生活的重要组成部分,用户能够获取旅游信息的渠道也随信息技术的广泛应用而增加。大量未经过滤的信息在展示给用户的同时,也淹没了用户真正感兴趣的信息。为了方便用户快速定位自己感兴趣......