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 智能移除图片中的物体、文本、污迹、人物或任何不想要的东西
相关推荐
aqi0013 小时前
15天学会AI应用开发(九)利用Chroma持久化向量数据金銀銅鐵13 小时前
借助 Pygame 探索最大公约数的规律ServBay1 天前
9 个 Python 第三方库推荐,不用 AI 都好像多出一个团队用户8356290780511 天前
如何使用 Python 添加和管理 Excel 批注(完整示例)用户8356290780511 天前
使用 Python 管理 Excel 工作表:创建、复制、删除与重命名SelectDB1 天前
阶跃星辰基于 SelectDB 构建 PB 级 Agent 可观测平台这个DBA有点耶1 天前
GROUP BY优化全解:如何写出既不丢数据又飞快的分组查询掉头发的王富贵1 天前
【StarRocks】极限十分钟入门StarRocksNturmoils1 天前
WHERE 条件别凭习惯写,常用查询先跑一遍