当前位置: 首页 > backend >正文

Python+MongoDb使用手册(精简)

这里是学了下面链接的内容,加上一些自己学习的内容综合的,大家也可以去看看这篇文章,写的特别好 【python】在Python中操作MongoDB的详细用法教程与实战案例分享_python轻松入门,基础语法到高阶实战教学-CSDN专栏

1 库:pymongo 

pip install pymongo

2 连接:MongoClient

from pymongo import MongoClient

#连接MongoDb

client=MongoClient('localhost',27017)

#选择或创建数据库

db=client['mongo_database']

#选择或创建集合

collection=db['mongo_collection']

3 语法

READ

#查询所有文档

collection.find()

#查询当个文档

collection.find_one()

#带条件查询

collection.find({"color":"red"})

#多条件查询($and,$or,$nor)

collection.find({ "$and": [ {"age": {"$gt": 25}}, {"city": "New York"} ] })

#模糊查询

collection.find("name":{"$regex":"^A"})

#结果打印

for doc in collection.find()

INSERT

#插入单条

collection.insert_one(doc)

#插入多条

collection.insert_many(docs)

UPDATE

#更新单个文档

query={"color":"red"}

newvalues={"$set":{"type":"flower"}}

collection.update_one(query,newvalues)

#更新多个文档

query={"color":"red"}

newvalues={"$set":{"type":"flower"}}

collection.update_many(query,newvalues)

DELETE

#删除单个文档

query={"color":"red"}

collection.delete_one(query)

#删除多个文档

query={"color":"green"}

collection.delete_many(query)

4.索引

#创建索引

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

#创建复合索引

collection.create_index([("color", pymongo.ASCENDING), ("type", pymongo.DESCENDING)])

5 聚合管道

# 使用聚合管道

pipeline = [

{"$match": {"color": "red"}},#先用$match筛选

{"$group": {"_id": "$type", "count": {"$sum": 1}}}#再用$group分组

6 事务

# 确保MongoDB在副本集模式下运行(事务需要副本集)

db = client['mydatabase']

with client.start_session() as session:

        with session.start_transaction(): # 在此执行事务操作

              collection1.insert_one(doc1, session=session)

              collection2.insert_one(doc2, session=session)

7 线程池

# 创建一个连接池, 操作完成后,连接会自动返回到连接池中

client = MongoClient('localhost', 27017, maxPoolSize=100)3

8 详解多条件查询

一、多条件组合查询
1. ‌隐式 AND 操作‌

多个条件在字典中并列时默认执行 AND 操作:

query = {
    "age": {"$gt": 25},      # 年龄大于25
    "city": "New York",      # 城市为纽约
    "status": "active"       # 状态为活跃
}
results = collection.find(query)  # 同时满足三个条件:ml-citation{ref="1,3" data="citationList"}

2. ‌显式逻辑运算符‌

使用 $and、$or 等运算符组合条件:
# AND 操作
query = {
    "$and": [
        {"age": {"$gte": 30}},
        {"salary": {"$lt": 5000}}
    ]
}

# OR 操作
query = {
    "$or": [
        {"department": "IT"},
        {"department": "HR"}
    ]
}
results = collection.find(query)  # 显式逻辑组合:ml-citation{ref="3" data="citationList"}

3. ‌混合逻辑操作‌

嵌套使用 $and 和 $or:
query = {
    "$and": [
        {"$or": [{"role": "manager"}, {"role": "director"}]},
        {"join_date": {"$gt": "2023-01-01"}}
    ]
}

二、嵌套字段查询

使用点记号访问嵌套字段:
query = {
    "address.city": "Beijing",
    "address.zip_code": {"$regex": "^10"}  # 邮编以10开头
}
results = collection.find(query)  # 嵌套结构查询

 三、更新操作的多条件
1. ‌更新单条文档‌ (update_one)
collection.update_one(
    {"name": "Alice", "status": "pending"},  # 查询条件
    {"$set": {"status": "completed"}}        # 更新操作
)  # 仅更新第一条匹配文档:ml-citation{ref="1,6" data="citationList"}

2. ‌批量更新‌ (update_many)
collection.update_many(
    {
        "department": "Finance",
        "level": {"$in": [3, 4]}             # 级别为3或4
    },
    {"$inc": {"salary": 1000}}               # 薪水增加1000
)  # 更新所有匹配文档:ml-citation{ref="6" data="citationList"}

collection.update_many(
    {"$and": [{"department": "IT"}, {"salary": {"$lt": 5000}}]},  # 同时满足两个条件
    {"$inc": {"salary": 1000}}  # 薪资增加1000
)  #:ml-citation{ref="6,9" data="citationList"}
 

 collection.update_many(
    {"$or": [{"department": "HR"}, {"department": "Finance"}]},  # 满足任意一个条件
    {"$set": {"bonus": 5000}}  # 设置奖金
)  #:ml-citation{ref="4,10" data="citationList"}

四、聚合框架中的多条件

在聚合管道中使用 $match 阶段:
pipeline = [
    {"$match": {
        "age": {"$gte": 30},
        "sales": {"$gt": 10000}
    }},
    {"$group": {
        "_id": "$department",
        "avg_sales": {"$avg": "$sales"}
    }}
]
results = collection.aggregate(pipeline)  # 多条件聚合

pipeline = [
    {"$match": {"$and": [{"age": {"$gte": 30}}, {"sales": {"$gt": 10000}}]}},  # 必须同时满足
    {"$group": {"_id": "$department", "avg_sales": {"$avg": "$sales"}}}
]  #:ml-citation{ref="9,11" data="citationList"}
 

pipeline = [ {"$match": {"$or": [{"status": "active"}, {"status": "pending"}]}}, # 满足其一即可 {"$count": "total"} ] #:ml-citation{ref="4,10" data="citationList"}

 

五、实用技巧

正则表达式查询‌
query = {"name": {"$regex": "^J", "$options": "i"}}  # 名字以J开头(不区分大小写)


数组条件查询‌
query = {"tags": {"$all": ["urgent", "VIP"]}}  # 同时包含urgent和VIP标签


排序与限制‌
results = collection.find(query).sort("create_time", -1).limit(10)  # 按时间倒序取前10条:ml-citation{ref="4" data="citationList"}

#隐式 $and‌ 多个并列条件默认按 $and 处理(等效于逗号分隔):

 {"age": {"$gt": 25}, "city": "New York"} # 隐式 AND:ml-citation{ref="5" data="citationList"} {"$and": [{"age": {"$gt": 25}}, {"city": "New York"}]} # 显式 AND

#嵌套

{"$and": [
    {"$or": [{"role": "manager"}, {"role": "director"}]},  # 角色为 manager 或 director
    {"join_year": {"$gte": 2020}}  # 且入职年份 ≥2020
]}  #:ml-citation{ref="5,9" data="citationList"}
 

#update 的修改部分(如 $set)需用逗号分隔字段,‌不可用 and‌:

# ✅ 正确写法
{"$set": {"field1": "A", "field2": "B"}}  

# ❌ 错误写法(导致逻辑错误)
{"$set": {"field1": "A" and "field2": "B"}}  #:ml-citation{ref="1,8" data="citationList"}
 

 

http://www.xdnf.cn/news/10447.html

相关文章:

  • python打卡day42
  • 学习日记-day20-6.1
  • 【AI论文】推理语言模型的强化学习熵机制
  • Cocos 打包 APK 兼容环境表(Android API Level 10~15)
  • 从线性代数到线性回归——机器学习视角
  • 获取 HTTP 请求从发送到接收响应所花费的总时间
  • 什么是缺页中断(缺页中断详解)
  • 基于微信小程序的垃圾分类系统
  • 西瓜书第十章——聚类
  • 思科设备网络实验
  • 鸿蒙OSUniApp集成WebAssembly实现高性能计算:从入门到实践#三方框架 #Uniapp
  • 开发指南120-表格(el-table)斑马纹
  • 无法运用pytorch环境、改环境路径、隔离环境
  • Python编程基础(二)| 列表简介
  • 【Redis】笔记|第4节|Redis数据安全性分析
  • 数据类型与推断:TypeScript 的基础
  • wordpress免费主题网站
  • ASP.NET Core SignalR 身份认证集成指南(Identity + JWT)
  • Spring Boot,注解,@ConfigurationProperties
  • 手拆STL
  • 【Redis技术进阶之路】「原理分析系列开篇」分析客户端和服务端网络诵信交互实现(服务端执行命令请求的过程 - 时间事件处理部分)
  • Selenium的底层原理
  • 鸿蒙OSUniApp声纹识别与语音验证:打造安全可靠的跨平台语音应用#三方框架 #Uniapp
  • 第14讲、Odoo 18 实现一个Markdown Widget模块
  • 网络攻防技术一:绪论
  • 如何编写GitLab-CI配置文件
  • 【Linux】Linux文件系统详解
  • Linux 简单模拟实现C语言文件流
  • res.json() vs res.send() 的区别
  • 03.MySQL表的操作详解