ArangoDB - क्रड संचालन
इस अध्याय में, हम आरंगोश के साथ विभिन्न कार्यों के बारे में जानेंगे।
आरंगोष के साथ संभावित संचालन निम्नलिखित हैं -
- दस्तावेज़ संग्रह बनाना
- दस्तावेज़ बनाना
- दस्तावेज़ पढ़ना
- अद्यतन दस्तावेज़
एक नया डेटाबेस बनाकर शुरू करते हैं। हम एक नया डेटाबेस बनाने के लिए निम्नलिखित लाइन ऑफ़ कोड का उपयोग करेंगे -
127.0.0.1:8529@_system> db._createDatabase("song_collection")
true
कोड की निम्नलिखित पंक्ति आपको नए डेटाबेस में स्थानांतरित करने में मदद करेगी -
127.0.0.1:8529@_system> db._useDatabase("song_collection")
true
प्रॉम्प्ट "@@ song_collection" पर स्थानांतरित हो जाएगा
127.0.0.1:8529@song_collection>
यहां से हम CRUD ऑपरेशन का अध्ययन करेंगे। आइए हम नए डेटाबेस में एक संग्रह बनाएँ -
127.0.0.1:8529@song_collection> db._createDocumentCollection('songs')
उत्पादन
[ArangoCollection 4890, "songs" (type document, status loaded)]
127.0.0.1:8529@song_collection>
हमारे 'गीत' संग्रह में कुछ दस्तावेज (JSON ऑब्जेक्ट्स) जोड़ें।
हम निम्नलिखित तरीके से पहला दस्तावेज़ जोड़ते हैं -
127.0.0.1:8529@song_collection> db.songs.save({title: "A Man's Best Friend",
lyricist: "Johnny Mercer", composer: "Johnny Mercer", Year: 1950, _key:
"A_Man"})
उत्पादन
{
"_id" : "songs/A_Man",
"_key" : "A_Man",
"_rev" : "_VjVClbW---"
}
डेटाबेस में अन्य दस्तावेज जोड़ते हैं। इससे हमें डेटा को क्वेरी करने की प्रक्रिया सीखने में मदद मिलेगी। आप इन कोड को कॉपी कर सकते हैं और प्रक्रिया का अनुकरण करने के लिए आरंगोश में समान पेस्ट कर सकते हैं -
127.0.0.1:8529@song_collection> db.songs.save(
{
title: "Accentchuate The Politics",
lyricist: "Johnny Mercer",
composer: "Harold Arlen", Year: 1944,
_key: "Accentchuate_The"
}
)
{
"_id" : "songs/Accentchuate_The",
"_key" : "Accentchuate_The",
"_rev" : "_VjVDnzO---"
}
127.0.0.1:8529@song_collection> db.songs.save(
{
title: "Affable Balding Me",
lyricist: "Johnny Mercer",
composer: "Robert Emmett Dolan",
Year: 1950,
_key: "Affable_Balding"
}
)
{
"_id" : "songs/Affable_Balding",
"_key" : "Affable_Balding",
"_rev" : "_VjVEFMm---"
}
दस्तावेज़ कैसे पढ़ें
_keyया दस्तावेज़ हैंडल का उपयोग किसी दस्तावेज़ को पुनः प्राप्त करने के लिए किया जा सकता है। डॉक्यूमेंट हैंडल का उपयोग करें यदि संग्रह को स्वयं से पार करने की कोई आवश्यकता नहीं है। यदि आपके पास एक संग्रह है, तो दस्तावेज़ फ़ंक्शन का उपयोग करना आसान है -
127.0.0.1:8529@song_collection> db.songs.document("A_Man");
{
"_key" : "A_Man",
"_id" : "songs/A_Man",
"_rev" : "_VjVClbW---",
"title" : "A Man's Best Friend",
"lyricist" : "Johnny Mercer",
"composer" : "Johnny Mercer",
"Year" : 1950
}
दस्तावेज़ कैसे अद्यतन करें
सहेजे गए डेटा को अपडेट करने के लिए दो विकल्प उपलब्ध हैं - replace तथा update।
अपडेट फ़ंक्शन एक दस्तावेज़ को पैच करता है, इसे दिए गए विशेषताओं के साथ विलय करता है। दूसरी ओर, प्रतिस्थापित फ़ंक्शन पिछले दस्तावेज़ को एक नए के साथ बदल देगा। प्रतिस्थापन तब भी होगा जब पूरी तरह से अलग-अलग विशेषताएँ प्रदान की जाती हैं। हम पहले एक गैर-विनाशकारी अपडेट का अवलोकन करेंगे, एक गीत में विशेषता Production` को अपडेट करते हुए -
127.0.0.1:8529@song_collection> db.songs.update("songs/A_Man",{production:
"Top Banana"});
उत्पादन
{
"_id" : "songs/A_Man",
"_key" : "A_Man",
"_rev" : "_VjVOcqe---",
"_oldRev" : "_VjVClbW---"
}
आइए अब पढ़ते हैं अपडेटेड गाने की खूबियाँ -
127.0.0.1:8529@song_collection> db.songs.document('A_Man');
उत्पादन
{
"_key" : "A_Man",
"_id" : "songs/A_Man",
"_rev" : "_VjVOcqe---",
"title" : "A Man's Best Friend",
"lyricist" : "Johnny Mercer",
"composer" : "Johnny Mercer",
"Year" : 1950,
"production" : "Top Banana"
}
एक बड़े दस्तावेज़ को आसानी से अपडेट किया जा सकता है update कार्य, विशेषकर जब विशेषताएँ बहुत कम हों।
इसके विपरीत, replace फ़ंक्शन आपके डेटा को उसी दस्तावेज़ के साथ उपयोग करने पर समाप्त कर देगा।
127.0.0.1:8529@song_collection> db.songs.replace("songs/A_Man",{production:
"Top Banana"});
आइए अब हम उस गीत की जाँच करें जिसे हमने कोड की निम्नलिखित पंक्ति के साथ अद्यतन किया है -
127.0.0.1:8529@song_collection> db.songs.document('A_Man');
उत्पादन
{
"_key" : "A_Man",
"_id" : "songs/A_Man",
"_rev" : "_VjVRhOq---",
"production" : "Top Banana"
}
अब, आप देख सकते हैं कि दस्तावेज़ में अब मूल डेटा नहीं है।
दस्तावेज़ कैसे निकालें
किसी संग्रह से दस्तावेज़ को निकालने के लिए दस्तावेज़ हैंडल के साथ संयोजन में फ़ंक्शन को हटा दिया जाता है -
127.0.0.1:8529@song_collection> db.songs.remove('A_Man');
आइए अब हम गीत की उन विशेषताओं को जांचते हैं जिन्हें हमने कोड की निम्नलिखित पंक्ति का उपयोग करके हटाया है -
127.0.0.1:8529@song_collection> db.songs.document('A_Man');
हमें आउटपुट के रूप में निम्न की तरह एक अपवाद त्रुटि मिलेगी -
JavaScript exception in file
'/usr/share/arangodb3/js/client/modules/@arangodb/arangosh.js' at 97,7:
ArangoError 1202: document not found
! throw error;
! ^
stacktrace: ArangoError: document not found
at Object.exports.checkRequestResult
(/usr/share/arangodb3/js/client/modules/@arangodb/arangosh.js:95:21)
at ArangoCollection.document
(/usr/share/arangodb3/js/client/modules/@arangodb/arango-collection.js:667:12)
at <shell command>:1:10