本文详解如何使用 pymongo 聚合管道(`$unwind` + `$match` + `$group`)从嵌套的 `pictures` 数组中检索所有满足正则匹配的子文档,并正确归并到对应父文档中,避免因冗余操作导致匹配项丢失。
在处理 MongoDB 中嵌套数组的模糊搜索时,一个常见误区是:在 $unwind 后使用 $match 筛选子文档,却未合理重建原始结构——尤其当试图通过 $replaceRoot 和 $mergeObjects “还原”根文档时,反而会破坏 $group 阶段对多个匹配项的聚合逻辑。
问题根源在于原 Pipeline 中混用了 $$ROOT 和字段级聚合(如 $first),同时又在后续阶段强行合并,导致每个 _id 分组仅保留了首个匹配的 pictures 子文档($addToSet 本身支持多值,但 $replaceRoot + $mergeObjects 的写法干扰了 pictures 数组的完整性)。
✅ 正确解法是精简聚合流程,专注“分组归并”本质:
以下是优化后的完整 Flask 路由实现:
import re
from flask import Flask, jsonify
from controller.database import client, database_name, temp_collection
app = Flask(__name__)
db = client[database_name]
collection = db[temp_collection]
@app.route('/component/find/', methods=['GET'])
def get_component(picture_name):
# 构建不区分大小写的正则模式
pattern = re.compile(picture_name, re.IGNORECASE)
pipeline = [
{"$unwind": "$pictures"},
{"$match": {"pictures.name": {"$regex": pattern}}},
{"$group": {
"_id": {"$toString": "$_id"}, # 确保 _id 可 JSON 序列化
"url": {"$first": "$url"},
"source": {"$first": "$source"},
"pictures": {"$push": "$pictures"} # ✅ 关键:用 $push 保留全部匹配项
}},
{"$project": {
"_id": 1,
"url": 1,
"source": 1,
"pictures": 1
}}
]
result = list(collection.aggregate(pipeline))
if result:
return jsonify(result)
else:
return jsonify({
"message": f"Component with picture '{picture_name}' not found."
}), 404
if __name__ == "__main__":
app.run(debug=True) ⚠️ 注意事项:
ngoDB 的 ObjectId 默认无法被 jsonify 序列化,{"$toString": "$_id"} 是安全做法;若需保持 ObjectId 格式,应在返回前手动转换(但前端通常更接受字符串 ID)。该方案简洁、可靠,能精确返回每个匹配父文档及其全部符合条件的嵌套子文档,完全符合预期输出格式。
# js
# 前端
# json
# go
# mongodb
# app
# ai
# 路由
# win
# gate
# flask
# 字符串
# Regex
# 类型转换
# 文档
# 序列化
# 这是
# 多个
# 出现在
# 应在
# 而非
# 首个
# 留了
# 如何使用
相关文章:
小说建站VPS选用指南:性能对比、配置优化与建站方案解析
建站之星如何修改网站生成路径?
广平建站公司哪家专业可靠?如何选择?
javascript基本数据类型及类型检测常用方法小结
正规网站制作公司有哪些,目前国内哪家网页网站制作设计公司比较专业靠谱?口碑好?
如何在服务器上三步完成建站并提升流量?
公司网站设计制作厂家,怎么创建自己的一个网站?
如何正确下载安装西数主机建站助手?
小自动建站系统:AI智能生成+拖拽模板,多端适配一键搭建
淘宝制作网站有哪些,淘宝网官网主页?
深圳网站制作公司好吗,在深圳找工作哪个网站最好啊?
深圳网站制作案例,网页的相关名词有哪些?
高端建站三要素:定制模板、企业官网与响应式设计优化
焦点电影公司作品,电影焦点结局是什么?
如何在宝塔面板创建新站点?
如何用搬瓦工VPS快速搭建个人网站?
洛阳网站制作公司有哪些,洛阳的招聘网站都有哪些?
济南专业网站制作公司,济南信息工程学校怎么样?
网站海报制作教学视频教程,有什么免费的高清可商用图片网站,用于海报设计?
开源网站制作软件,开源网站什么意思?
网站视频制作书签怎么做,ie浏览器怎么将网站固定在书签工具栏?
如何选择高效稳定的ISP建站解决方案?
智能起名网站制作软件有哪些,制作logo的软件?
建站之星24小时客服电话如何获取?
设计网站制作公司有哪些,制作网页教程?
三星网站视频制作教程下载,三星w23网页如何全屏?
如何通过商城免费建站系统源码自定义网站主题?
网站制作壁纸教程视频,电脑壁纸网站?
香港代理服务器配置指南:高匿IP选择、跨境加速与SEO优化技巧
南平网站制作公司,2025年南平市事业单位报名时间?
如何用腾讯建站主机快速创建免费网站?
如何在Golang中使用encoding/gob序列化对象_存储和传输数据
,石家庄四十八中学官网?
如何选择美橙互联多站合一建站方案?
建站之星如何保障用户数据免受黑客入侵?
中山网站制作网页,中山新生登记系统登记流程?
在线制作视频网站免费,都有哪些好的动漫网站?
C#怎么使用委托和事件 C# delegate与event编程方法
合肥制作网站的公司有哪些,合肥聚美网络科技有限公司介绍?
魔方云NAT建站如何实现端口转发?
高端网站建设与定制开发一站式解决方案 中企动力
免费视频制作网站,更新又快又好的免费电影网站?
我的世界制作壁纸网站下载,手机怎么换我的世界壁纸?
如何在搬瓦工VPS快速搭建网站?
如何用AWS免费套餐快速搭建高效网站?
弹幕视频网站制作教程下载,弹幕视频网站是什么意思?
javascript中的try catch异常捕获机制用法分析
专业商城网站制作公司有哪些,pi商城官网是哪个?
如何用PHP工具快速搭建高效网站?
建站之星安装失败:服务器环境不兼容?
*请认真填写需求信息,我们会在24小时内与您取得联系。