小胖细说MongoDB特性 --- MongoDB collMod

一直以来想做一个关于MongoDB的系列专题,但又没有中心思想,所以一直拖着,但现在想想大可不必。完全可以东打一枪,西放一炮。
所以有了今天的第一篇文章。

今天就来说说runCommand的collMod命令

首先我们先来盘算一下,MongoDB创建集合的方式有哪几种:

  • 对希望创建的collection插入数据
    db.<collection_name>.insert({<field>: <value>})

  • 通过对collection创建索引
    db.<collection_name>.createIndex({<field>:1}

  • 调用官方API接口显式创建
    db.createCollection(<collection_name>

从MongoDB 3.2开始,官方提供了相应接口对Schema作强一致性的策略:
当数据进行Insert或者Update的时候,通过创建集合时的validator option的参数控制,按照自定义的validation rules 或者 expressions,达到数据强一致性检查。

db.createCollection( "contacts",
   { validator: { $or:
      [
         { phone: { $type: "string" } },
         { email: { $regex: /@mongodb\.com$/ } },
         { status: { $in: [ "Unknown", "Incomplete" ] } }
      ]
   }
} )

这里提供了3种验证方式,满足一种即可。若是$and,则需要同时满足。

若不满足,MongoDB将会返回121错误,提示Document failed validation,插入0条。

该特性对MongoDB的Schemaless以及对DBA维护MongoDB表结构、规范等提供了相当大的帮助。

下面图1既是引用官方文档关于validation level的定义:

《小胖细说MongoDB特性 --- MongoDB collMod》 图1 validationLevel

validationLevelDescription
“off”关闭数据校验。
“strict”默认值。对所有的update和insert有效。
“moderate”仅对insert和满足校验规则的document做update有效。对已存在的不符合校验规则的document无效。

下面图2既是引用官方文档关于validation action的定义:

《小胖细说MongoDB特性 --- MongoDB collMod》 图2 validationAction

validationActionDescription
“error”默认值。document必须满足校验规则,才能被写入数据哭。
“warn”document不符合校验规则的,MongoDB允许写入,但会记录一条告警到mongod.log中去。日志内容记录报错信息以及该document的完整记录。
db.runCommand( { collMod: "contacts",
                 validator: { $or:
                    [
                       { phone: { $type: "string" } },
                       { email: { $regex: /@mongodb\.com$/ } },
                       { status: { $in: [ "Unknown", "Incomplete" ] } }
                    ]
                 },
                 validationLevel: "moderate",
                 validationAction: "warn"

} )

总结

collMod的作用是非常明显的,可以帮助DBA去规避之前由于Schemaless而无法约束开发的窘境。可以就collMod来规范MongoDB的开发过程。
有必要使用强一致性对相应MongoDB数据作统一规划。

    原文作者:上海小胖
    原文地址: https://www.jianshu.com/p/3d00ceb0953a
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞