如何保证MongoDB文档的数据质量_JSON Schema验证规则配置

MongoDB 5.0+ 启用 JSON Schema 验证需显式配置 validator、validationLevel(推荐 strict)和 validationAction(建议先设 warn);schema 不自动映射 ObjectId/Date,需正则或 format 校验;嵌套字段须 properties 逐层定义,数组用 items;开启后不合规写入将报错,回滚仅能通过 collMod 修改 validator 或 validationAction。如何在 MongoDB 5.0+ 中启用 JSON Schema 验证MongoDB 原生支持 JSON Schema 验证,但不是默认开启的------必须显式配置 validator 并设置 validationLevel 和 validationAction。不配这两项,即使写了 schema 也完全不生效。validationLevel 推荐设为 strict(仅对新插入/更新文档校验),避免历史脏数据导致集合不可写validationAction 建议先用 warn:校验失败只打日志,不阻断写入,方便灰度观察必须通过 collMod 命令或 createCollection 一次性声明,不能后期"补加" validator 到已有集合(除非重建)JSON Schema 字段类型与 MongoDB 类型的对应陷阱JSON Schema 的 string、number 等类型不会自动映射到 MongoDB 的 ObjectId、Date 或 BinData。比如写 {"type": "string"},MongoDB 会接受任意字符串,但不会拒绝一个形如 "507f1f77bcf86cd799439011" 的 ObjectId 字符串------它仍是合法 string。需要 ObjectId 校验?得用 pattern + 正则:{"pattern": "^0-9a-fA-F{24}$"}需要 Date 校验?不能只靠 "type": "string",得加 "format": "date-time",且客户端写入时必须是 ISO 字符串(如 "2023-10-05T12:34:56Z"),MongoDB 不会把数字时间戳(如 1696509296000)自动转成 Daterequired 只检查字段是否存在,不检查是否为 null;要排除 null,得额外加 "not": {"type": "null"}嵌套对象和数组的验证写法差异对 address.city 这类路径校验,不能直接在顶层 schema 写 "address.city": {"type": "string"} ------ JSON Schema 不支持点号路径,必须用 properties 逐层嵌套。 Cleanup.pictures 智能移除图片中的物体、文本、污迹、人物或任何不想要的东西

相关推荐
老毛肚1 小时前
jeecg-boot-base-core 02 day
javascript·python
yaoxin5211232 小时前
434. Java 日期时间 API - Period 基于日期的时间段
java·开发语言·python
岁月宁静3 小时前
RAG 文档摄入全链路,从原理到生产落地
vue.js·人工智能·python
火山上的企鹅3 小时前
Codex实战:APP远程升级服务搭建(三)后台管理页面(APK 上传、版本管理、多应用页签)
服务器·网络·数据库·oracle·qgc
程序员二叉3 小时前
【JUC】线程池全套深度详解|参数|流程|拒绝策略|调优|异常处理
java·开发语言·jvm·算法·面试·juc
JaydenAI3 小时前
[对比学习LangChain和MAF-07]如何引入人机交互的审批流程
python·ai·langchain·c#·agent·hitl·maf
阿狸猿3 小时前
论 NoSQL 数据库技术及其应用
数据库·nosql
神奇元创4 小时前
商用级光路加速卡:大模型推理的极速落地方案
python·神经网络·fpga开发·dsp开发
FBI HackerHarry浩4 小时前
DataGrip2023.2.3默认保存的数据库和.sql文件在哪里?怎么修改默认路径?
数据库
袁小皮皮不皮4 小时前
3.HCIP OSPF补充知识(优化版)
服务器·网络·数据库·网络协议·智能路由器