推荐默认用 deleted_at 字段实现软删除,因其支持删除时间记录与按时间恢复,需配稀疏索引;若仅需二态且无审计需求,可用 is_deleted 布尔字段加普通索引。软删除字段该用 is_deleted 还是 deleted_at两者都能实现软删除,但语义和查询效率差异明显:is_deleted 是布尔值,索引小、查询快;deleted_at 是时间戳,能记录删除时间、支持按时间恢复或归档,但索引体积大、范围查询更重。常见错误是只加 is_deleted 却没建索引,导致 find({is_deleted: false}) 全表扫描;或者用 deleted_at: null 表示未删除,结果 null 值不进 MongoDB 索引(除非用稀疏索引或显式存 ISODate("1970-01-01"))。推荐默认用 deleted_at: {type: Date, default: null},删时设为 new Date(),查时用 {deleted_at: {eq: null}}必须为 deleted_at 建稀疏索引:db.collection.createIndex({deleted_at: 1}, {sparse: true}),否则 null 值不被索引覆盖如果业务只要"删/不删"二态,且无审计需求,is_deleted: {type: Boolean, default: false} + 普通索引更轻量MongoDB 查询里漏掉软删除条件的典型写法开发者常在聚合、更新、删除操作中忘记过滤已删除文档,比如 updateOne({name: "foo"}, {...}) 直接改了已删除的旧记录,导致数据逻辑错乱。最稳妥的做法是:所有读写操作都显式带上软删除条件,而不是靠中间件或全局钩子------后者容易被绕过或遗漏。查列表:find({deleted_at: {eq: null}, status: "active"}),别写成 find({status: "active"})更新前先校验:updateOne({ _id: id, deleted_at: {eq: null} }, { set: { ... } }),匹配数为 0 就说明文档已被软删除聚合时在 match 阶段尽早过滤:{match: {deleted_at: {$eq: null}}},避免后续阶段处理无效数据用 TTL 索引自动清理软删除数据的风险有人想用 deleted_at 字段配 TTL 索引,让 MongoDB 定期物理删除老的软删除文档。这看起来省事,但实际埋雷。 跃问 跃问是由阶跃星辰开发的免费AI智能问答助手,随时帮你智能搜索、高效阅读、识图理解、和你畅聊感兴趣的话题。
相关推荐
weixin_408717771 小时前
mysql权限表查询性能如何优化_MySQL系统权限缓存原理想唱rap2 小时前
C++智能指针吕源林2 小时前
如何解决SQL存储过程连接泄露_确保在异常后关闭连接weixin_447443252 小时前
AI启蒙Lean4Gofarlic_OMS2 小时前
应对MathWorks合规审查的专项准备工作野生技术架构师2 小时前
牛客网热门Java 面试题汇总,查漏补缺;多线程 +spring+JVM 调优 + 分布式 +redis+ 算法Ulyanov2 小时前
雷达电子战仿真通信需求与Python实现挑战七夜zippoe2 小时前
DolphinDB SQL查询:从基础到进阶有想法的py工程师2 小时前
PostgreSQL 深入heap_update() 与 HOT 机制(附源码级解析)