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会自动创建该集合。

相关推荐
小云数据库服务专线13 分钟前
GaussDB数据库架构师修炼(十六) 如何选择磁盘
数据库·数据库架构·gaussdb
码出财富1 小时前
SQL语法大全指南
数据库·mysql·oracle
异世界贤狼转生码农3 小时前
MongoDB Windows 系统实战手册:从配置到数据处理入门
数据库·mongodb
QuZhengRong3 小时前
【数据库】Navicat 导入 Excel 数据乱码问题的解决方法
android·数据库·excel
码农阿豪3 小时前
Windows从零到一安装KingbaseES数据库及使用ksql工具连接全指南
数据库·windows
时序数据说9 小时前
时序数据库市场前景分析
大数据·数据库·物联网·开源·时序数据库
听雪楼主.12 小时前
Oracle Undo Tablespace 使用率暴涨案例分析
数据库·oracle·架构
我科绝伦(Huanhuan Zhou)12 小时前
KINGBASE集群日常维护管理命令总结
数据库·database
妖灵翎幺12 小时前
Java应届生求职八股(2)---Mysql篇
数据库·mysql
HMBBLOVEPDX12 小时前
MySQL的事务日志:
数据库·mysql