यदि आप मोंगो संस्करण 3.6 का उपयोग कर रहे हैं, तो आप $jsonSchema
का उपयोग करके स्कीमा सत्यापन को सक्षम कर सकते हैं सर्वर साइड पर
हमारे द्वारा अपडेट/सम्मिलित प्रत्येक दस्तावेज़ को सत्यापन स्कीमा के विरुद्ध मान्य किया जाएगा, यह सत्यापन विफल रहता है एक त्रुटि फेंक दी जाएगी और दस्तावेज़ पर कोई संशोधन नहीं किया जाएगा
नमूना node
संग्रह स्कीमा
{
_id : string,
parent : [string, null],
children : string[2]
}
सत्यापन स्कीमा
db.createCollection("node", {
validator: {
$jsonSchema: {
bsonType: "object",
required: [ "_id" ],
properties: {
parent: {
bsonType: ["string", "null"],
description: "must be a string"
},
children: {
bsonType: ["array"],
items : { bsonType: ["string"] },
minItems: 0,
maxItems: 2,
description: "must be a array of string and max is 2"
}
}
}
}
});
सम्मिलित करता है [वैध दस्तावेजों के साथ]
> db.node.insert( { _id: "Books", children: [ "Programming" ], parent: null } )
WriteResult({ "nInserted" : 1 })
> db.node.insert( { _id: "Programming", children: [ "Databases", "Languages" ], parent: "Books" } )
WriteResult({ "nInserted" : 1 })
> db.node.insert( { _id: "Languages", children: [ ], parent: "Programming" } )
WriteResult({ "nInserted" : 1 })
> db.node.insert( { _id: "Databases", children: [ "MongoDB", "dbm" ], parent: "Programming" } )
WriteResult({ "nInserted" : 1 })
> db.node.insert( { _id: "MongoDB", children: [ ], parent: "Databases" } )
WriteResult({ "nInserted" : 1 })
> db.node.insert( { _id: "dbm", children: [ ], parent: "Databases" } )
WriteResult({ "nInserted" : 1 })
>
ढूँढें
> db.node.find()
{ "_id" : "Books", "children" : [ "Programming" ], "parent" : null }
{ "_id" : "Programming", "children" : [ "Databases", "Languages" ], "parent" : "Books" }
{ "_id" : "Languages", "children" : [ ], "parent" : "Programming" }
{ "_id" : "Databases", "children" : [ "MongoDB", "dbm" ], "parent" : "Programming" }
{ "_id" : "MongoDB", "children" : [ ], "parent" : "Databases" }
{ "_id" : "dbm", "children" : [ ], "parent" : "Databases" }
अमान्य दस्तावेज़ के साथ डालें [बच्चों का आकार> 2]
> db.node.insert({_id : "1", children : ["c1", "c2", "c3"], parent : "p1"})
WriteResult({
"nInserted" : 0,
"writeError" : {
"code" : 121,
"errmsg" : "Document failed validation"
}
})
>
सत्यापन त्रुटि के साथ सम्मिलित करना विफल रहा
अद्यतन - _id डेटाबेस के लिए तीसरे बच्चे को जोड़ने का प्रयास, सत्यापन त्रुटि के साथ विफल
> db.node.updateOne( { _id: "Databases"}, {$push : {children: [ "Oracle" ]}} )
2018-02-25T21:00:08.087+0530 E QUERY [thread1] WriteError: Document failed validation :
WriteError({
"index" : 0,
"code" : 121,
"errmsg" : "Document failed validation",
"op" : {
"q" : {
"_id" : "Databases"
},
"u" : {
"$push" : {
"children" : [
"Oracle"
]
}
},
"multi" : false,
"upsert" : false
}
})
[email protected]/mongo/shell/bulk_api.js:466:48
Bulk/[email protected]/mongo/shell/bulk_api.js:846:49
Bulk/[email protected]/mongo/shell/bulk_api.js:910:13
Bulk/[email protected]/mongo/shell/bulk_api.js:1154:21
[email protected]/mongo/shell/crud_api.js:572:17
@(shell):1:1
>
कृपया schema-validation देखें &jsonSchema अधिक विकल्पों के लिए, मौजूदा संग्रह में सत्यापन जोड़ना और सत्यापन विफलताओं को संभालना