MongoDB में, $objectToArray
एकत्रीकरण पाइपलाइन ऑपरेटर एक दस्तावेज़ को एक सरणी में परिवर्तित करता है।
$objectToArray
. द्वारा निर्मित सरणी मूल दस्तावेज़ में प्रत्येक फ़ील्ड/मान जोड़ी के लिए एक तत्व होता है। प्रत्येक तत्व एक दस्तावेज़ है जिसमें एक k
. होता है फ़ील्ड और एक v
फ़ील्ड:
- द
k
फ़ील्ड में मूल दस्तावेज़ में फ़ील्ड का नाम होता है। - द
v
फ़ील्ड में मूल दस्तावेज़ में फ़ील्ड का मान होता है।
उदाहरण
मान लीजिए हमारे पास dogs
. नामक संग्रह है निम्नलिखित दस्तावेज़ के साथ:
{ "_id" : 1, "name" : "Fetch", "specs" : { "height" : 400, "weight" : 55, "color" : "brown" } }
हम $objectToArray
. का उपयोग कर सकते हैं ऑपरेटर को specs
लौटाने के लिए एक सरणी के रूप में फ़ील्ड:
db.dogs.aggregate(
[
{ $match: { _id: { $in: [ 1 ] } } },
{ $project: {
_id: 0,
result: { $objectToArray: "$specs" } }
}
]
).pretty()
परिणाम:
{ "result" : [ { "k" : "height", "v" : 400 }, { "k" : "weight", "v" : 55 }, { "k" : "color", "v" : "brown" } ] }
नेस्टेड दस्तावेज़
$objectToArray
ऑपरेटर केवल शीर्ष स्तर के क्षेत्र पर लागू होता है। यह किसी भी एम्बेडेड दस्तावेज़ पर पुनरावर्ती रूप से लागू नहीं होता है।
मान लीजिए हमारे पास इस तरह का एक दस्तावेज़ है:
{ "_id" : 2, "name" : "Wag", "specs" : { "height" : 50, "weight" : 5, "color" : { "eyes" : "brown", "coat" : "black" } } }
यहां बताया गया है कि जब हम $objectToArray
. लागू करते हैं तो क्या होता है उस दस्तावेज़ के लिए:
db.dogs.aggregate(
[
{ $match: { _id: { $in: [ 2 ] } } },
{ $project: {
_id: 0,
result: { $objectToArray: "$specs" } }
}
]
).pretty()
परिणाम:
{ "result" : [ { "k" : "height", "v" : 50 }, { "k" : "weight", "v" : 5 }, { "k" : "color", "v" : { "eyes" : "brown", "coat" : "black" } } ] }
इस मामले में, शीर्ष स्तर के दस्तावेज़ को k
. में बदल दिया जाता है /v
प्रारूप, लेकिन एम्बेडेड दस्तावेज़ मूल दस्तावेज़ के समान ही रहता है।
गलत प्रकार
$objectToArray
. को दिया गया तर्क जब तक यह किसी दस्तावेज़ ऑब्जेक्ट का समाधान करता है तब तक कोई भी मान्य अभिव्यक्ति हो सकती है।
यदि तर्क दस्तावेज़ ऑब्जेक्ट का समाधान नहीं करता है, तो एक त्रुटि उत्पन्न होती है।
मान लीजिए हमारे पास निम्नलिखित दस्तावेज़ हैं:
{ "_id" : 3, "name" : "Fetch", "specs" : "None" }
specs
फ़ील्ड में एक स्ट्रिंग है।
यहां बताया गया है कि जब हम $objectToArray
. लागू करते हैं तो क्या होता है उस दस्तावेज़ के लिए:
db.dogs.aggregate(
[
{ $match: { _id: { $in: [ 3 ] } } },
{ $project: {
_id: 0,
result: { $objectToArray: "$specs" } }
}
]
)
परिणाम:
uncaught exception: Error: command failed: { "ok" : 0, "errmsg" : "$objectToArray requires a document input, found: string", "code" : 40390, "codeName" : "Location40390" } : aggregate failed : [email protected]/mongo/shell/utils.js:25:13 [email protected]/mongo/shell/assert.js:18:14 [email protected]/mongo/shell/assert.js:639:17 [email protected]/mongo/shell/assert.js:729:16 [email protected]/mongo/shell/db.js:266:5 [email protected]/mongo/shell/collection.js:1058:12 @(shell):1:1
जैसा कि त्रुटि बताती है, $objectToArray requires a document input
।
शून्य मान
null
प्रदान करना परिणाम null
।
मान लीजिए हमारे पास निम्नलिखित दस्तावेज़ हैं:
{ "_id" : 4, "name" : "Fetch", "specs" : null }
और हम $objectToArray
. लागू करते हैं :
db.dogs.aggregate(
[
{ $match: { _id: { $in: [ 4 ] } } },
{ $project: {
_id: 0,
result: { $objectToArray: "$specs" } }
}
]
)
परिणाम:
{ "result" : null }
अनुपलब्ध फ़ील्ड
यदि फ़ील्ड अनुपलब्ध है, तो परिणाम null
है ।
मान लीजिए हमारे पास निम्नलिखित दस्तावेज़ हैं:
{ "_id" : 5, "name" : "Fetch" }
और हम $objectToArray
. लागू करते हैं :
db.dogs.aggregate(
[
{ $match: { _id: { $in: [ 5 ] } } },
{ $project: {
_id: 0,
result: { $objectToArray: "$specs" } }
}
]
)
परिणाम:
{ "result" : null }