Python与MongoDB交互的代码实现

 更新时间:2024年10月08日 10:57:08   作者:卡布达ovo  
Python与MongoDB的交互通常通过pymongo库来实现,pymongo是一个官方的Python驱动程序,用于与MongoDB数据库进行交互,以下是一个简单的示例,具有一定的参考价值,需要的朋友可以参考下

Python与MongoDB的交互通常通过pymongo库来实现。pymongo是一个官方的Python驱动程序,用于与MongoDB数据库进行交互。以下是一个简单的示例,展示了如何使用pymongo来连接到MongoDB数据库,执行一些基本的数据库操作(如插入、查询、更新和删除文档)。

安装pymongo

pip install pymongo

Python连接Mongodb

from pymongo import MongoClient
 
# 创建一个MongoClient对象,该对象用于连接Mongodb数据库服务器
client = MongoClient('mongodb://admin:password@localhost:27017/')

向数据库中添加数据

from mongo_db import client
 
# client.school.teacher.insert_one({"name": "露娜"})
 
# client.school.teacher.insert_many([{"name":"兰陵王"}, {"name": "百里玄策"}])
 
client.school.teacher.find({})

查询数据

from mongo_db import client
 
try:
    teachers = client.school.teacher.find()
    # print(teachers)
    for one in teachers:
        print(one["_id"],one["name"])
 
    # 有条件查询
    teacher = client.school.teacher.find_one({"name":"兰陵王"})
    print(teacher["_id"],teacher["name"])
 
except Exception  as e:
    print(e)

更新修改数据

from mongo_db import client
 
try:
    # 全表修改,表中无此列时会增加此列
    # client.school.teacher.update_many({}, {'$set': {"role":["班主任"]}})
    # client.school.teacher.update_one({"name": "露娜"},{"$set":{"sex": "女"}})
 
    # push追加(列表)
    client.school.teacher.update_one({"name": "露娜"},{"$push":{"role": "年级王主任"}})
 
except Exception as e:
    print(e)

删除数据

from mongo_db import client
 
try:
    # 有条件查询
    # client.school.teacher.delete_one({"name": "露娜"})
    # 删除多条数据
    client.school.teacher.delete_many({})
except Exception as e:
    print(e)

索引 

创建索引以优化查询性能。

collection.create_index([("name", pymongo.ASCENDING)])

聚合框架 

使用聚合框架进行复杂的数据聚合操作

pipeline = [
    {"$match": {"age": {"$gt": 25}}},
    {"$group": {"_id": "$city", "count": {"$sum": 1}}}
]
results = collection.aggregate(pipeline)
for result in results:
    print(result)

事务 

从MongoDB 4.0开始,支持多文档事务,确保数据的一致性和完整性。

with client.start_session() as session:
    with session.start_transaction():
        collection.update_one({"name": "John"}, {"$set": {"age": 32}}, session=session)
        collection.update_one({"name": "Alice"}, {"$set": {"age": 26}}, session=session)
        session.commit_transaction()

关闭连接

client.close()

注意事项

在使用pymongo进行MongoDB操作时,需要确保MongoDB服务已经启动并且网络连接正常。

在进行数据插入、更新和删除操作时,需要注意数据的完整性和一致性。

MongoDB的集合是动态创建的,即当向一个不存在的集合插入数据时,MongoDB会自动创建该集合。

到此这篇关于Python与MongoDB交互的代码实现的文章就介绍到这了,更多相关Python与MongoDB交互内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 从零开始理解如何使用Python搭建智能AI代理

    从零开始理解如何使用Python搭建智能AI代理

    Agentic AI(智能代理)正在悄然改变我们的工作方式,所以这篇文章小编就来和大家简单介绍一下如何使用Python搭建智能AI代理,感兴趣的小伙伴可以了解下
    2025-07-07
  • Python简单计算文件MD5值的方法示例

    Python简单计算文件MD5值的方法示例

    这篇文章主要介绍了Python简单计算文件MD5值的方法,涉及Python文件读取、hash运算及md5加密等相关操作技巧,需要的朋友可以参考下
    2018-04-04
  • Python微信企业号开发之回调模式接收微信端客户端发送消息及被动返回消息示例

    Python微信企业号开发之回调模式接收微信端客户端发送消息及被动返回消息示例

    这篇文章主要介绍了Python微信企业号开发之回调模式接收微信端客户端发送消息及被动返回消息的方法,涉及Python微信企业号回调模式消息响应机制相关操作技巧,需要的朋友可以参考下
    2017-08-08
  • 如何利用Python统计正数和负数的个数

    如何利用Python统计正数和负数的个数

    Python检查数据中的正/负数是一种常见的数据处理操作,可以通过编写代码来实现,下面这篇文章主要给大家介绍了关于如何利用Python统计正数和负数的个数的相关资料,需要的朋友可以参考下
    2024-05-05
  • Python 中的 Counter 模块及使用详解(搞定重复计数)

    Python 中的 Counter 模块及使用详解(搞定重复计数)

    Counter 是一个简单的计数器,用于统计某些可哈希对象的数量。它以字典的形式存储元素和它们的计数,这篇文章主要介绍了Python 中的 Counter 模块及使用详解(搞定重复计数),需要的朋友可以参考下
    2023-04-04
  • Python DataFrame Rank详解

    Python DataFrame Rank详解

    在数据分析中,pandas库的DataFrame对象的rank()方法可用于计算数据排名,处理重复值并支持多种参数定制排名规则,如ascending、axis、numeric_only等,是数据分析和竞赛中的有力工具
    2024-09-09
  • pandas DataFrame mul的具体实现

    pandas DataFrame mul的具体实现

    pandas.DataFrame.mul() 方法用于执行逐元素的乘法操作,本文主要介绍了pandas DataFrame mul的具体实现,具有一定的参考价值,感兴趣的可以了解一下
    2025-04-04
  • 如何基于python实现不邻接植花

    如何基于python实现不邻接植花

    这篇文章主要介绍了如何基于python实现不邻接植花,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-05-05
  • Python Django路径配置实现过程解析

    Python Django路径配置实现过程解析

    这篇文章主要介绍了Python Django路径配置实现过程解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-11-11
  • Python进度条神器tqdm使用实例详解

    Python进度条神器tqdm使用实例详解

    Python进度条神器tqdm是一个快速、可扩展的进度条工具,可以轻松地为Python脚本添加进度条。它可以在循环中自动计算进度,并在终端中显示进度条,让用户了解程序的运行情况。tqdm还支持多线程和多进程,并且可以自定义进度条的样式和显示方式。
    2023-06-06

最新评论