推荐默认用 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智能问答助手,随时帮你智能搜索、高效阅读、识图理解、和你畅聊感兴趣的话题。
相关推荐
m0_463672201 小时前
如何快速检索SQL中的隐藏字符_使用转义与函数处理老纪1 小时前
JavaScript中BigInt与Number类型混用的报错机制档案宝档案管理1 小时前
全文检索 vs 条件检索 vs 目录检索:适用场景对比庞轩px1 小时前
第二篇:Redis的过期删除与内存淘汰——数据过期了怎么删?内存满了怎么办?学习论之费曼学习法1 小时前
Agent安全与防护:防止Prompt注入和数据泄露m0_741481781 小时前
HTML函数在低温环境下启动慢吗_温度对硬件启动影响【方法】zjy277771 小时前
mysql如何利用覆盖索引加速统计_mysqlcount查询优化05候补工程师1 小时前
【Python实战】告别杂乱脚本!基于SOLID原则与策略模式的 PDF转Word 批量处理系统Biomamba生信基地1 小时前
拷贝数变异分析的python实现及R语言对比