mongodb字段驗(yàn)證規(guī)則(schema validation)

在我們通常的印象中,mongodb是模式自由的(schemaless),可以往一個(gè)集合里插入任意類型的數(shù)據(jù),這會(huì)帶來一些問題,例如對(duì)于PHP這種弱類型的語言,一個(gè)本應(yīng)該是int型的字段,可能會(huì)同時(shí)存在string和int類型的數(shù)據(jù)。

例如一個(gè)集合members,存儲(chǔ)會(huì)員信息,包含的文檔如下

> db.members.find();
{ "_id" : ObjectId("5b62a5c73eeb75204f15dbe3"), "user_id" : 100, "level" : "vip" }
{ "_id" : ObjectId("5b62a5cb3eeb75204f15dbe4"), "user_id" : 101, "level" : "vip" }
{ "_id" : ObjectId("5b62a5db3eeb75204f15dbe5"), "user_id" : "102", "level" : "gold" }
{ "_id" : ObjectId("5b62a5e53eeb75204f15dbe6"), "user_id" : 102, "level" : "gold" }

集合中有user_id為102和"102"的兩個(gè)文檔,按user_id查詢

> db.members.find({user_id:{$eq:102}});
{ "_id" : ObjectId("5b62a5e53eeb75204f15dbe6"), "user_id" : 102, "level" : "gold" }
> db.members.find({user_id:{$eq:"102"}});
{ "_id" : ObjectId("5b62a5db3eeb75204f15dbe5"), "user_id" : "102", "level" : "gold" }

可以看出102和"102"查詢出了不同的結(jié)果。

問題來了,開發(fā)語言為弱類型語言,導(dǎo)致同一個(gè)字段寫入了不同類型的值,這很容易引起bug。

是否可以對(duì)mongodb的字段類型進(jìn)行約束呢?很不幸,mongodb 3.2之前的版本不支持本操作。

幸運(yùn)的是,mongodb從版本3.2開始引入了schema validation,可以為集合指定驗(yàn)證規(guī)則。

我們?yōu)閙embers集合指定驗(yàn)證規(guī)則,限定user_id必須為int類型,且不可或缺。

> db.runCommand({collMod:"members", validator:{$and:[{"user_id":{$type:"int", $exists:true}}]}});
{ "ok" : 1 }

嘗試插入user_id為string類型的數(shù)據(jù),可以看出驗(yàn)證失敗了。

> db.members.insert({user_id:"102", level:"gold"});
Document failed validation

我們還可以在創(chuàng)建集合時(shí)就指定驗(yàn)證規(guī)則

> db.createCollection("test_members", {validator:{$and:[{"user_id":{$type:"int", $exists:true}}]}});
{ "ok" : 1 }

參考文檔

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 本篇文章主要匯總MongoDB的一些核心知識(shí)點(diǎn),以及在Python和PHP中的使用,持續(xù)更新,力爭(zhēng)清晰全面,便于作...
    聶云?閱讀 771評(píng)論 0 4
  • 第十六天 redis-sentinel 監(jiān)控 自動(dòng)選主,切換(6381 slaveof no one) 2號(hào)從庫(...
    燮_0e5d閱讀 409評(píng)論 0 0
  • 關(guān)于Mongodb的全面總結(jié) MongoDB的內(nèi)部構(gòu)造《MongoDB The Definitive Guide》...
    中v中閱讀 32,288評(píng)論 2 89
  • 一、MongoDB簡(jiǎn)介 1.概述 ? MongoDB是一個(gè)基于分布式文件存儲(chǔ)的數(shù)據(jù)庫,由C++語言編寫。旨在為WE...
    鄭元吉閱讀 1,118評(píng)論 0 2
  • 1. 邏輯結(jié)構(gòu) Mongodb 邏輯結(jié)構(gòu) MySQL邏輯結(jié)構(gòu)庫database 庫集合(collection) 表...
    火雞不肥閱讀 271評(píng)論 0 0

友情鏈接更多精彩內(nèi)容