应全局复用单个MongoClient实例,DAO函数接收collectionName字符串并内部获取句柄;find返回游标需显式处理,findOne须确保查询字段有索引;update/delete操作必须限定filter、慎用upsert和空条件,错误需判MongoServerError提取码。怎么用原生 mongodb 驱动写可复用的 CRUD 函数直接封装 collection.insertOne、collection.find 这些调用,别碰 ODM(比如 Mongoose),核心是把连接、db 实例、collection 名抽出来,让业务代码只关心"查什么""改什么"。常见错误:每次操作都重新 new MongoClient 或反复 client.db().collection() ------ 连接池被绕过,压测时秒变超时。全局复用一个 MongoClient 实例,启动时连接,关机时 close()DAO 函数接收 collectionName 字符串,内部通过 db.collection(collectionName) 获取句柄,不硬编码 collection所有方法返回 Promise,统一用 async/await,避免回调地狱和未捕获异常find 和 findOne 的参数怎么传才不踩坑findOne 和 find 看似一样,但行为差异直接影响性能和内存------尤其在分页或大结果集场景。典型问题:用 find({}).toArray() 加载 10 万条记录到内存,Node 进程 OOM;或者 findOne 忘加 _id 索引,慢查询拖垮整个服务。findOne 只返回单个文档,适合查主键或唯一字段,必须确保查询字段有索引(比如 { userId: 1 })find 返回游标(Cursor),要显式调用 .toArray()、.limit().skip() 或 .forEach();分页务必用 .limit(n).skip(m),别先 toArray() 再切片过滤条件一律用纯对象,别传字符串或函数;$regex 尽量配合 ^ 前缀,否则无法走索引updateOne 和 updateMany 的写法差异影响数据一致性用错更新方法会导致部分数据没改、或意外改多------尤其是带时间戳、计数器等需要原子操作的字段。 MacsMind 电商AI超级智能客服
相关推荐
生信研究猿2 小时前
#P3492.第1题-基于决策树预判资源调配优先级梦想的旅途22 小时前
企微自动化办公:实现外部群聊的高级交互逻辑Captain_Data2 小时前
Meta裁员8000人:AI驱动组织重构的技术解析abc123456sdggfd2 小时前
php怎么实现API网关聚合_php如何将多个微服务接口合并响应LiAo_1996_Y2 小时前
JavaScript中类属性与原型属性的覆盖规则详解2301_817672262 小时前
如何修改Oracle服务器的主机名_listener和tnsnames同步调整snow@li10 小时前
数据库:市场中都有哪些数据库 / 优缺点 使用情况kishu_iOS&AI10 小时前
深度学习 —— 损失函数好运的阿财10 小时前
OpenClaw工具拆解之canvas+message