ArangoDB - त्वरित गाइड

ArangoDB अपने डेवलपर्स द्वारा एक देशी बहु-मॉडल डेटाबेस के रूप में प्रतिष्ठित है। यह अन्य NoSQL डेटाबेस के विपरीत है। इस डेटाबेस में, डेटा को दस्तावेज़, कुंजी / मूल्य जोड़े या ग्राफ़ के रूप में संग्रहीत किया जा सकता है। और एक एकल घोषणात्मक क्वेरी भाषा के साथ, आपके किसी भी या सभी डेटा तक पहुँचा जा सकता है। इसके अलावा, विभिन्न मॉडलों को एक ही क्वेरी में जोड़ा जा सकता है। और, इसकी मल्टी-मॉडल शैली के कारण, एक दुबला आवेदन कर सकता है, जो क्षैतिज रूप से किसी भी या सभी तीन डेटा मॉडल के साथ स्केलेबल होगा।

लेयर्ड बनाम नेटिव मल्टी-मॉडल डेटाबेस

इस खंड में, हम मूल और स्तरित मल्टीमॉडल डेटाबेस के बीच एक महत्वपूर्ण अंतर को उजागर करेंगे।

कई डेटाबेस विक्रेता अपने उत्पाद को "मल्टी-मॉडल" कहते हैं, लेकिन एक कुंजी / मूल्य या दस्तावेज़ स्टोर में ग्राफ़ की परत को जोड़ने से मूल मल्टी-मॉडल के रूप में अर्हता प्राप्त नहीं होती है।

ArangoDB के साथ, एक ही क्वेरी भाषा के साथ एक ही कोर, एक ही क्वेरी में विभिन्न डेटा मॉडल और सुविधाओं को एक साथ क्लब कर सकते हैं, जैसा कि हम पहले ही पिछले भाग में बता चुके हैं। ArangoDB में, डेटा मॉडल के बीच कोई "स्विचिंग" नहीं है, और प्रश्नों को निष्पादित करने के लिए A से B तक डेटा की शिफ्टिंग नहीं है। यह "स्तरित" दृष्टिकोण की तुलना में अरेंजबीडी को प्रदर्शन लाभ देता है।

मल्टीमॉडल डेटाबेस की आवश्यकता

[फाउलर] के मूल विचार की व्याख्या करने से हमें दृढ़ता के विभिन्न भागों के लिए उपयुक्त डेटा मॉडल का उपयोग करने के लाभों का एहसास होता है, परत बड़े सॉफ्टवेयर आर्किटेक्चर का हिस्सा है।

इसके अनुसार, एक, उदाहरण के लिए, संरचित, सारणीबद्ध डेटा को बनाए रखने के लिए एक संबंधपरक डेटाबेस का उपयोग कर सकता है; असंरचित, वस्तु की तरह डेटा के लिए एक दस्तावेज़ की दुकान; एक हैश तालिका के लिए एक कुंजी / मूल्य की दुकान; और अत्यधिक जुड़े संदर्भ डेटा के लिए एक ग्राफ डेटाबेस।

हालांकि, इस दृष्टिकोण के पारंपरिक कार्यान्वयन से एक ही परियोजना में कई डेटाबेस का उपयोग किया जा सकेगा। यह कुछ परिचालन घर्षण (अधिक जटिल तैनाती, अधिक लगातार उन्नयन) के साथ-साथ डेटा स्थिरता और दोहराव के मुद्दों को जन्म दे सकता है।

तीन डेटा मॉडल के लिए डेटा को एकीकृत करने के बाद अगली चुनौती, एक सामान्य क्वेरी भाषा को तैयार करना और लागू करना है जो डेटा प्रशासक को विभिन्न प्रकार के प्रश्नों को व्यक्त करने की अनुमति दे सकती है, जैसे कि दस्तावेज़ प्रश्न, कुंजी / मूल्य लुकअप, ग्राफी प्रश्न और मनमाना संयोजन। इनमे से।

द्वारा graphy queries, हमारा मतलब ग्राफ-थ्योरिटिकल विचार से जुड़े प्रश्नों से है। विशेष रूप से, इनमें किनारों से आने वाली विशेष कनेक्टिविटी सुविधाएँ शामिल हो सकती हैं। उदाहरण के लिए,ShortestPath, GraphTraversal, तथा Neighbors

रेखांकन संबंधों के लिए डेटा मॉडल के रूप में एक आदर्श फिट हैं। कई वास्तविक दुनिया के मामलों जैसे कि सामाजिक नेटवर्क, अनुशंसा प्रणाली, आदि में, एक बहुत ही प्राकृतिक डेटा मॉडल एक ग्राफ है। यह संबंधों को पकड़ता है और प्रत्येक किनारे के साथ और प्रत्येक शीर्ष के साथ लेबल जानकारी पकड़ सकता है। इसके अलावा, JSON दस्तावेज़ इस प्रकार के शीर्ष और किनारे डेटा को संग्रहीत करने के लिए एक प्राकृतिक फिट हैं।

ArangoDB। सुविधाएँ

ArangoDB की विभिन्न उल्लेखनीय विशेषताएं हैं। हम नीचे प्रमुख विशेषताओं पर प्रकाश डालेंगे -

  • मल्टी-मॉडल प्रतिमान
  • ACID गुण
  • HTTP एपीआई

ArangoDB सभी लोकप्रिय डेटाबेस मॉडल का समर्थन करता है। ArangoDB द्वारा समर्थित कुछ मॉडल निम्नलिखित हैं -

  • दस्तावेज़ मॉडल
  • कुंजी / मूल्य मॉडल
  • ग्राफ मॉडल

एक एकल क्वेरी भाषा डेटा को डेटाबेस से बाहर निकालने के लिए पर्याप्त है

चार गुण Atomicity, Consistency, Isolation, तथा Durability(ACID) डेटाबेस लेनदेन की गारंटी का वर्णन करता है। ArangoDB ACID-अनुरूप लेनदेन का समर्थन करता है।

ArangoDB क्लाइंट, जैसे ब्राउज़र, HTTP API के साथ डेटाबेस से संपर्क करने की अनुमति देता है, API संसाधन-उन्मुख और जावास्क्रिप्ट के साथ विस्तार योग्य है।

ArangoDB का उपयोग करने के फायदे निम्नलिखित हैं -

समेकन

एक देशी मल्टी-मॉडल डेटाबेस के रूप में, अरेंजगोबीडी कई डेटाबेस को तैनात करने की आवश्यकता को समाप्त करता है, और इस प्रकार घटकों की संख्या और उनके रखरखाव में कमी करता है। नतीजतन, यह अनुप्रयोग के लिए प्रौद्योगिकी-स्टैक जटिलता को कम करता है। आपकी समग्र तकनीकी आवश्यकताओं को समेकित करने के अलावा, इस सरलीकरण से स्वामित्व की कुल लागत कम हो जाती है और लचीलापन बढ़ जाता है।

सरलीकृत प्रदर्शन स्केलिंग

समय के साथ बढ़ते अनुप्रयोगों के साथ, अलग-अलग डेटा मॉडल के साथ स्वतंत्र रूप से स्केलिंग करके, अरंगबोबे बढ़ते प्रदर्शन और भंडारण की जरूरतों से निपट सकते हैं। जैसा कि अरेंजबीडीबी लंबवत और क्षैतिज रूप से दोनों को माप सकता है, इसलिए यदि आपका प्रदर्शन कम हो जाता है (जानबूझकर, वांछित धीमी गति से), तो आपके बैक-एंड सिस्टम को हार्डवेयर के साथ-साथ परिचालन लागतों को बचाने के लिए आसानी से बढ़ाया जा सकता है।

कम परिचालन जटिलता

Polyglot Persistence का फरमान आपके द्वारा किए जाने वाले प्रत्येक कार्य के लिए सर्वोत्तम टूल को नियोजित करना है। कुछ कार्यों के लिए एक दस्तावेज़ डेटाबेस की आवश्यकता होती है, जबकि अन्य को ग्राफ़ डेटाबेस की आवश्यकता हो सकती है। एकल-मॉडल डेटाबेस के साथ काम करने के परिणामस्वरूप, यह कई परिचालन चुनौतियों को जन्म दे सकता है। एकल-मॉडल डेटाबेस को एकीकृत करना अपने आप में एक कठिन काम है। लेकिन सबसे बड़ी चुनौती अलग, असंबद्ध डेटाबेस सिस्टम के बीच डेटा स्थिरता और गलती सहिष्णुता के साथ एक बड़ा सामंजस्यपूर्ण संरचना का निर्माण है। यह लगभग असंभव साबित हो सकता है।

Polyglot Persistence को एक देशी मल्टी-मॉडल डेटाबेस के साथ संभाला जा सकता है, क्योंकि यह polyglot डेटा को आसानी से रखने की अनुमति देता है, लेकिन साथ ही एक गलती सहिष्णु प्रणाली पर डेटा स्थिरता के साथ। ArangoDB के साथ, हम जटिल नौकरी के लिए सही डेटा मॉडल का उपयोग कर सकते हैं।

मजबूत डेटा संगति

यदि कोई एक एकल-मॉडल डेटाबेस का उपयोग करता है, तो डेटा संगतता एक समस्या बन सकती है। ये डेटाबेस एक-दूसरे के साथ संवाद करने के लिए डिज़ाइन नहीं किए गए हैं, इसलिए आपके डेटा को विभिन्न मॉडलों के बीच सुसंगत रखने के लिए कुछ प्रकार की लेनदेन कार्यक्षमता को लागू करने की आवश्यकता है।

ACID लेनदेन का समर्थन करते हुए, ArangoDB क्लस्टर मोड में काम करते समय, एक ही उदाहरण पर मजबूत स्थिरता प्रदान करता है, और परमाणु संचालन के साथ आपके विभिन्न डेटा मॉडल का प्रबंधन करता है।

दोष सहिष्णुता

कई असंबंधित घटकों के साथ दोष सहिष्णु प्रणालियों का निर्माण करना एक चुनौती है। समूहों के साथ काम करने पर यह चुनौती और अधिक जटिल हो जाती है। विभिन्न तकनीकों और / या प्रौद्योगिकी के ढेर का उपयोग करके ऐसी प्रणालियों को तैनात करने और बनाए रखने के लिए विशेषज्ञता की आवश्यकता होती है। इसके अलावा, कई उप-प्रणालियों को एकीकृत करते हुए, स्वतंत्र रूप से चलाने के लिए डिज़ाइन किया गया है, जो बड़ी इंजीनियरिंग और परिचालन लागत को प्रभावित करता है।

समेकित प्रौद्योगिकी स्टैक के रूप में, मल्टी-मॉडल डेटाबेस एक सुरुचिपूर्ण समाधान प्रस्तुत करता है। विभिन्न डेटा मॉडल के साथ आधुनिक, मॉड्यूलर आर्किटेक्चर को सक्षम करने के लिए डिज़ाइन किया गया, अरंगबॉब क्लस्टर उपयोग के लिए भी काम करता है।

स्वामित्व की कम कुल लागत

प्रत्येक डेटाबेस प्रौद्योगिकी के लिए निरंतर रखरखाव, बग फिक्सिंग पैच, और अन्य कोड परिवर्तन की आवश्यकता होती है जो विक्रेता द्वारा प्रदान किए जाते हैं। एक मल्टी-मॉडल डेटाबेस को गले लगाने से एप्लिकेशन को डिज़ाइन करने में डेटाबेस प्रौद्योगिकियों की संख्या को समाप्त करके संबंधित रखरखाव की लागत में काफी कमी आती है।

लेनदेन

कई मशीनों में लेन-देन की गारंटी प्रदान करना एक वास्तविक चुनौती है, और कुछ NoSQL डेटाबेस ये गारंटी देते हैं। देशी मल्टी-मॉडल होने के नाते, ArangoDB डेटा स्थिरता की गारंटी के लिए लेनदेन करता है।

इस अध्याय में, हम ArangoDB के लिए मूल अवधारणाओं और शब्दावली पर चर्चा करेंगे। हम जिस तकनीकी विषय से निपट रहे हैं, उससे संबंधित अंतर्निहित बुनियादी शब्दावली का ज्ञान होना बहुत महत्वपूर्ण है।

ArangoDB के लिए शब्दावली नीचे सूचीबद्ध हैं -

  • Document
  • Collection
  • संग्रह पहचानकर्ता
  • संग्रह का नाम
  • Database
  • डेटाबेस नाम
  • डेटाबेस संगठन

डेटा मॉडल के दृष्टिकोण से, अरंगबोब को एक दस्तावेज़-उन्मुख डेटाबेस माना जा सकता है, क्योंकि दस्तावेज़ की धारणा बाद के गणितीय विचार है। दस्तावेज़ उन्मुख डेटाबेस NoSQL डेटाबेस की मुख्य श्रेणियों में से एक हैं।

पदानुक्रम इस तरह से होता है: दस्तावेजों को संग्रह में वर्गीकृत किया जाता है, और संग्रह डेटाबेस के अंदर मौजूद होते हैं

यह स्पष्ट होना चाहिए कि पहचानकर्ता और नाम संग्रह और डेटाबेस के लिए दो विशेषताएँ हैं।

आमतौर पर, दस्तावेज़ संग्रह में संग्रहीत दो दस्तावेज़ (कोने) एक किनारे में संग्रहीत दस्तावेज़ (किनारे) से जुड़े होते हैं। यह ArangoDB का ग्राफ डेटा मॉडल है। यह एक निर्देशित, लेबल ग्राफ की गणितीय अवधारणा का अनुसरण करता है, सिवाय इसके कि किनारों में केवल लेबल नहीं हैं, लेकिन पूर्ण विकसित दस्तावेज हैं।

इस डेटाबेस के लिए मुख्य शब्दों से परिचित होने के बाद, हम ArangoDB के ग्राफ डेटा मॉडल को समझने लगते हैं। इस मॉडल में, दो प्रकार के संग्रह मौजूद हैं: दस्तावेज़ संग्रह और किनारे संग्रह। एज कलेक्शन डॉक्यूमेंट्स को स्टोर करते हैं और इसमें दो विशेष विशेषताएँ भी शामिल हैं: पहला है_from विशेषता, और दूसरा है _toविशेषता। इन विशेषताओं का उपयोग ग्राफ़ डेटाबेस के लिए आवश्यक दस्तावेजों के बीच किनारों (संबंध) बनाने के लिए किया जाता है। दस्तावेज़ संग्रह को ग्राफ़ के संदर्भ में वर्टेक्स संग्रह भी कहा जाता है (कोई भी ग्राफ़ सिद्धांत पुस्तक देखें)।

आइए अब देखते हैं कि डेटाबेस कितने महत्वपूर्ण हैं। वे महत्वपूर्ण हैं क्योंकि संग्रह डेटाबेस के अंदर मौजूद हैं। ArangoDB के एक उदाहरण में, एक या कई डेटाबेस हो सकते हैं। अलग-अलग डेटाबेस आमतौर पर बहु-किरायेदार सेटअप के लिए उपयोग किए जाते हैं, क्योंकि उनके अंदर डेटा के विभिन्न सेट (संग्रह, दस्तावेज, आदि) एक दूसरे से अलग-थलग हैं। डिफ़ॉल्ट डेटाबेस_systemविशेष है, क्योंकि इसे हटाया नहीं जा सकता। उपयोगकर्ताओं को इस डेटाबेस में प्रबंधित किया जाता है, और उनकी साख सर्वर के सभी डेटाबेस के लिए मान्य होती है।

इस अध्याय में, हम ArangoDB के लिए सिस्टम आवश्यकताओं पर चर्चा करेंगे।

ArangoDB के लिए सिस्टम आवश्यकताएँ निम्नानुसार हैं -

  • उबंटू इंस्टॉलेशन वाला एक VPS सर्वर
  • रैम: 1 जीबी; सीपीयू: 2.2 गीगाहर्ट्ज़

इस ट्यूटोरियल में सभी कमांड्स के लिए, हमने उबंटू 16.04 (xenial) का RAM 1GB RAM का उपयोग किया है, जिसमें एक सीपीयू के साथ प्रोसेसिंग पावर 2.2 गीगाहर्ट्ज़ है। और इस ट्यूटोरियल में सभी आरंगोश कमांड्स को अरंगबीडीबी संस्करण 3.1.27 के लिए परीक्षण किया गया था।

ArangoDB कैसे स्थापित करें?

इस अनुभाग में, हम देखेंगे कि अरणगोबीडी को कैसे स्थापित किया जाए। ArangoDB कई ऑपरेटिंग सिस्टम और वितरण के लिए पूर्व-निर्मित आता है। अधिक जानकारी के लिए, कृपया अरेंजबीडी प्रलेखन देखें। जैसा कि पहले ही उल्लेख किया गया है, इस ट्यूटोरियल के लिए हम Ubuntu 16.04x64 का उपयोग करेंगे।

पहला कदम अपनी रिपॉजिटरी के लिए सार्वजनिक कुंजी डाउनलोड करना है -

# wget https://www.arangodb.com/repositories/arangodb31/
xUbuntu_16.04/Release.key

उत्पादन

--2017-09-03 12:13:24-- https://www.arangodb.com/repositories/arangodb31/xUbuntu_16.04/Release.key 
Resolving https://www.arangodb.com/
(www.arangodb.com)... 104.25.1 64.21, 104.25.165.21,
2400:cb00:2048:1::6819:a415, ... 
Connecting to https://www.arangodb.com/
(www.arangodb.com)|104.25. 164.21|:443... connected. 
HTTP request sent, awaiting response... 200 OK 
Length: 3924 (3.8K) [application/pgpkeys]
Saving to: ‘Release.key’
Release.key 100%[===================>] 3.83K - .-KB/s in 0.001s
2017-09-03 12:13:25 (2.61 MB/s) - ‘Release.key’ saved [39 24/3924]

महत्वपूर्ण बात यह है कि आपको देखना चाहिए Release.key आउटपुट के अंत में सहेजा गया।

कोड की निम्नलिखित पंक्ति का उपयोग करके सहेजे गए कुंजी को स्थापित करें -

# sudo apt-key add Release.key

उत्पादन

OK

उपयुक्त भंडार जोड़ने और सूचकांक को अद्यतन करने के लिए निम्नलिखित कमांड्स चलाएं -

# sudo apt-add-repository 'deb
https://www.arangodb.com/repositories/arangodb31/xUbuntu_16.04/ /'
# sudo apt-get update

अंतिम चरण के रूप में, हम ArangoDB स्थापित कर सकते हैं -

# sudo apt-get install arangodb3

उत्पादन

Reading package lists... Done
Building dependency tree
Reading state information... Done
The following package was automatically installed and is no longer required:
grub-pc-bin
Use 'sudo apt autoremove' to remove it.
The following NEW packages will be installed:
arangodb3
0 upgraded, 1 newly installed, 0 to remove and 17 not upgraded.
Need to get 55.6 MB of archives.
After this operation, 343 MB of additional disk space will be used.

दबाएँ Enter। अब ArangoDB स्थापित करने की प्रक्रिया शुरू होगी -

Get:1 https://www.arangodb.com/repositories/arangodb31/xUbuntu_16.04
arangodb3 3.1.27 [55.6 MB]
Fetched 55.6 MB in 59s (942 kB/s)
Preconfiguring packages ...
Selecting previously unselected package arangodb3.
(Reading database ... 54209 files and directories currently installed.)
Preparing to unpack .../arangodb3_3.1.27_amd64.deb ...

Unpacking arangodb3 (3.1.27) ...
Processing triggers for systemd (229-4ubuntu19) ...
Processing triggers for ureadahead (0.100.0-19) ...
Processing triggers for man-db (2.7.5-1) ...
Setting up arangodb3 (3.1.27) ...
Database files are up-to-date.

जब ArangoDB की स्थापना पूरी होने वाली है, तो निम्न स्क्रीन दिखाई देती है -

यहां, आपको ArangoDB के लिए एक पासवर्ड प्रदान करने के लिए कहा जाएगा rootउपयोगकर्ता। इसे ध्यान से देखें।

को चुनिए yes विकल्प जब निम्नलिखित संवाद बॉक्स प्रकट होता है -

जब आप क्लिक करेंगे Yesजैसा कि उपरोक्त डायलॉग बॉक्स में, निम्न डायलॉग बॉक्स दिखाई देता है। क्लिकYes यहाँ।

आप निम्न कमांड के साथ अरंगबोब की स्थिति भी देख सकते हैं -

# sudo systemctl status arangodb3

उत्पादन

arangodb3.service - LSB: arangodb
Loaded: loaded (/etc/init.d/arangodb3; bad; vendor pre set: enabled)
Active: active (running) since Mon 2017-09-04 05:42:35 UTC;
4min 46s ago
Docs: man:systemd-sysv-generator(8)
Process: 2642 ExecStart=/etc/init.d/arangodb3 start (code = exited,
status = 0/SUC
Tasks: 22
Memory: 158.6M
CPU: 3.117s
CGroup: /system.slice/arangodb3.service
├─2689 /usr/sbin/arangod --uid arangodb
--gid arangodb --pid-file /va
└─2690 /usr/sbin/arangod --uid arangodb
--gid arangodb --pid-file /va
Sep   04 05:42:33   ubuntu-512  systemd[1]:        Starting LSB:  arangodb...
Sep   04 05:42:33   ubuntu-512  arangodb3[2642]:  * Starting arango database server a
Sep   04 05:42:35   ubuntu-512  arangodb3[2642]:   {startup} starting up in daemon mode
Sep   04 05:42:35   ubuntu-512  arangodb3[2642]:   changed working directory for child
Sep   04 05:42:35   ubuntu-512  arangodb3[2642]:   ...done. 
Sep   04 05:42:35   ubuntu-512  systemd[1]:        StartedLSB: arang odb.
Sep   04 05:46:59   ubuntu-512  systemd[1]:        Started LSB: arangodb. lines 1-19/19 (END)

ArangoDB अब उपयोग करने के लिए तैयार है।

आरंगोश टर्मिनल का आह्वान करने के लिए, टर्मिनल में निम्नलिखित कमांड टाइप करें -

# arangosh

उत्पादन

Please specify a password:

की आपूर्ति root स्थापना के समय बनाया गया पासवर्ड -

_
__ _ _ __ __ _ _ __ __ _ ___ | |
/ | '__/ _ | ’ \ / ` |/ _ / | ’
| (| | | | (| | | | | (| | () _ \ | | |
_,|| _,|| ||_, |_/|/| ||
|__/
arangosh (ArangoDB 3.1.27 [linux] 64bit, using VPack 0.1.30, ICU 54.1, V8
5.0.71.39, OpenSSL 1.0.2g 1 Mar 2016)

Copyright (c) ArangoDB GmbH

Pretty printing values.
Connected to ArangoDB 'http+tcp://127.0.0.1:8529' version: 3.1.27 [server],
database: '_system', username: 'root'

Please note that a new minor version '3.2.2' is available
Type 'tutorial' for a tutorial or 'help' to see common examples
127.0.0.1:8529@_system> exit

ArangoDB से लॉग आउट करने के लिए, निम्न कमांड टाइप करें -

127.0.0.1:8529@_system> exit

उत्पादन

Uf wiederluege! Na shledanou! Auf Wiedersehen! Bye Bye! Adiau! ¡Hasta luego!
Εις το επανιδείν!

להתראות ! Arrivederci! Tot ziens! Adjö! Au revoir! さようなら До свидания! Até
Breve! !خداحافظ

इस अध्याय में, हम चर्चा करेंगे कि आरंगशो अर्न्गोबीडी के लिए कमांड लाइन के रूप में कैसे काम करता है। हम डेटाबेस उपयोगकर्ता को जोड़ना सीखेंगे।

Note - याद रखें कि संख्यात्मक कीपैड आरंगोश पर काम नहीं कर सकता है।

आइए हम मान लें कि उपयोगकर्ता "harry" है और पासवर्ड "hpwdb" है।

127.0.0.1:8529@_system> require("org/arangodb/users").save("harry", "hpwdb");

उत्पादन

{
   "user" : "harry",
   "active" : true,
   "extra" : {},
   "changePassword" : false,
   "code" : 201
}

इस अध्याय में, हम यह जानेंगे कि प्रमाणीकरण को कैसे सक्षम / अक्षम किया जाए, और सार्वजनिक नेटवर्क इंटरफ़ेस के लिए अरंगबोड को कैसे बाँधें।

# arangosh --server.endpoint tcp://127.0.0.1:8529 --server.database "_system"

यह आपको पहले से सहेजे गए पासवर्ड के लिए संकेत देगा -

Please specify a password:

कॉन्फ़िगरेशन के लिए आपने रूट के लिए जो पासवर्ड बनाया है, उसका उपयोग करें।

आप यह जाँचने के लिए कर्ल का उपयोग कर सकते हैं कि आपको वास्तव में HTTP 401 (अनधिकृत) सर्वर प्रतिक्रियाएँ मिल रही हैं, जिन्हें प्रमाणीकरण की आवश्यकता है -

# curl --dump - http://127.0.0.1:8529/_api/version

उत्पादन

HTTP/1.1 401 Unauthorized
X-Content-Type-Options: nosniff
Www-Authenticate: Bearer token_type = "JWT", realm = "ArangoDB"
Server: ArangoDB
Connection: Keep-Alive
Content-Type: text/plain; charset = utf-8
Content-Length: 0

हमारी सीखने की प्रक्रिया के दौरान हर बार पासवर्ड दर्ज करने से बचने के लिए, हम प्रमाणीकरण को अक्षम कर देंगे। उसके लिए, कॉन्फ़िगरेशन फ़ाइल खोलें -

# vim /etc/arangodb3/arangod.conf

यदि कोड ठीक से दिखाई नहीं दे रहा है, तो आपको रंग योजना बदल देनी चाहिए।

:colorscheme desert

नीचे दिए गए स्क्रीनशॉट में दिखाए अनुसार प्रमाणीकरण को गलत पर सेट करें।

सेवा को फिर से शुरू करें -

# service arangodb3 restart

प्रमाणीकरण को गलत बनाने पर, आप (जैसे रूट या सृजित उपयोगकर्ता के साथ) लॉगिन कर सकेंगे Harry इस मामले में) किसी भी पासवर्ड को दर्ज किए बिना please specify a password

आइए हम जाँच करें api संस्करण जब प्रमाणीकरण बंद हो जाता है -

# curl --dump - http://127.0.0.1:8529/_api/version

उत्पादन

HTTP/1.1 200 OK
X-Content-Type-Options: nosniff
Server: ArangoDB
Connection: Keep-Alive
Content-Type: application/json; charset=utf-8
Content-Length: 60
{"server":"arango","version":"3.1.27","license":"community"}

इस अध्याय में, हम दो उदाहरण परिदृश्यों पर विचार करेंगे। इन उदाहरणों को समझना आसान है और हमें ऐरंगबीडी कार्यक्षमता के काम करने के तरीके को समझने में मदद करेगा।

एपीआई प्रदर्शित करने के लिए, ArangoDB आसानी से समझने योग्य ग्राफ़ के एक सेट के साथ पहले से लोड हो जाता है। आपके अरण्गोबीडी में इन ग्राफ़ों के उदाहरण बनाने के लिए दो तरीके हैं -

  • वेब इंटरफ़ेस में ग्राफ़ विंडो बनाएँ उदाहरण टैब जोड़ें,
  • या मॉड्यूल लोड करें @arangodb/graph-examples/example-graph आरंगोश में।

शुरू करने के लिए, आइए हम वेब इंटरफेस की मदद से एक ग्राफ लोड करें। उसके लिए, वेब इंटरफ़ेस लॉन्च करें और उस पर क्लिक करेंgraphs टैब।

Create Graphसंवाद बॉक्स प्रकट होता है। विज़ार्ड में दो टैब होते हैं -Examples तथा GraphGraphटैब डिफ़ॉल्ट रूप से खुला है; यह मानकर कि हम एक नया ग्राफ बनाना चाहते हैं, यह ग्राफ के लिए नाम और अन्य परिभाषाओं के लिए पूछेगा।

अब, हम पहले से बनाए गए ग्राफ को अपलोड करेंगे। इसके लिए हम सेलेक्ट करेंगेExamples टैब।

हम तीन उदाहरण रेखांकन देख सकते हैं। को चुनिएKnows_Graph और ग्रीन बटन क्रिएट पर क्लिक करें।

एक बार जब आप उन्हें बना लेते हैं, तो आप उन्हें वेब इंटरफ़ेस में निरीक्षण कर सकते हैं - जिसका उपयोग नीचे दी गई तस्वीरों को बनाने के लिए किया गया था।

द नोज़_ग्राफ

आइये अब देखते हैं कि कैसे Knows_Graphकाम करता है। Knows_Graph का चयन करें, और यह ग्राफ़ डेटा लाएगा।

नोज़_ग्राफ में एक शीर्ष संग्रह होता है persons एक किनारे संग्रह के माध्यम से जुड़ा हुआ है knows। इसमें पांच व्यक्ति एलिस, बॉब, चार्ली, डेव और ईव को कोने के रूप में शामिल किया जाएगा। हमारे पास निम्नलिखित निर्देशित संबंध होंगे

Alice knows Bob
Bob knows Charlie
Bob knows Dave
Eve knows Alice
Eve knows Bob

यदि आप एक नोड (वर्टेक्स) पर क्लिक करते हैं, तो 'बॉब' कहें, यह आईडी (व्यक्तियों / बॉब) विशेषता नाम दिखाएगा।

और किसी भी किनारे पर क्लिक करने पर, यह आईडी (पता / 4590) विशेषताओं को दिखाएगा।

यह हम इसे कैसे बनाते हैं, इसके कोने और किनारों का निरीक्षण करते हैं।

आइए एक और ग्राफ जोड़ें, इस बार आरंगोश का उपयोग करते हुए। उसके लिए, हमें ArangoDB कॉन्फ़िगरेशन फ़ाइल में एक और समापन बिंदु शामिल करने की आवश्यकता है।

एकाधिक समापन बिंदु कैसे जोड़ें

कॉन्फ़िगरेशन फ़ाइल खोलें -

# vim /etc/arangodb3/arangod.conf

नीचे दिए गए टर्मिनल स्क्रीनशॉट में दिखाए गए अनुसार एक और समापन बिंदु जोड़ें।

ArangoDB पुनः आरंभ करें -

# service arangodb3 restart

आरंगोश लॉन्च करें -

# arangosh
Please specify a password:
_
__ _ _ __ __ _ _ __ __ _ ___ ___| |__
/ _` | '__/ _` | '_ \ / _` |/ _ \/ __| '_ \
| (_| | | | (_| | | | | (_| | (_) \__ \ | | |
\__,_|_| \__,_|_| |_|\__, |\___/|___/_| |_|
|___/
arangosh (ArangoDB 3.1.27 [linux] 64bit, using VPack 0.1.30, ICU 54.1, V8
5.0.71.39, OpenSSL 1.0.2g 1 Mar 2016)
Copyright (c) ArangoDB GmbH
Pretty printing values.
Connected to ArangoDB 'http+tcp://127.0.0.1:8529' version: 3.1.27
[server], database: '_system', username: 'root'
Please note that a new minor version '3.2.2' is available
Type 'tutorial' for a tutorial or 'help' to see common examples
127.0.0.1:8529@_system>

द सोशल_ग्राफ

आइए अब समझते हैं कि Social_Graph क्या है और यह कैसे काम करता है। ग्राफ व्यक्तियों और उनके संबंधों का एक सेट दिखाता है -

इस उदाहरण में महिला और पुरुष व्यक्तियों के दो शीर्ष संग्रह - स्त्री और पुरुष - में वर्टिकल हैं। किनारों उनके कनेक्शन संबंध संग्रह में हैं। हमने आरंगोश का उपयोग करके इस ग्राफ को बनाने का तरीका बताया है। पाठक इसके चारों ओर काम कर सकता है और इसकी विशेषताओं का पता लगा सकता है, जैसा कि हमने Knows_Graph के साथ किया था।

इस अध्याय में, हम निम्नलिखित विषयों पर ध्यान केंद्रित करेंगे -

  • डेटाबेस इंटरेक्शन
  • डेटा मॉडल
  • डेटा की पुनःप्राप्ति

ArangoDB दस्तावेज़ आधारित डेटा मॉडल के साथ-साथ ग्राफ़ आधारित डेटा मॉडल का समर्थन करता है। हमें पहले दस्तावेज़ आधारित डेटा मॉडल का वर्णन करें।

ArangoDB के दस्तावेज़ बारीकी से JSON प्रारूप से मिलते जुलते हैं। शून्य या अधिक विशेषताएँ एक दस्तावेज़ में निहित हैं, और प्रत्येक विशेषता के साथ एक मूल्य जुड़ा हुआ है। मान या तो एक परमाणु प्रकार का होता है, जैसे कि संख्या, बूलियन या अशक्त, शाब्दिक स्ट्रिंग, या मिश्रित डेटा प्रकार, जैसे एम्बेडेड दस्तावेज़ / ऑब्जेक्ट या एक सरणी। सरणी या उप-ऑब्जेक्ट में इन डेटा प्रकार शामिल हो सकते हैं, जिसका अर्थ है कि एक एकल दस्तावेज़ गैर-तुच्छ डेटा संरचनाओं का प्रतिनिधित्व कर सकता है।

आगे पदानुक्रम में, दस्तावेजों को संग्रह में व्यवस्थित किया जाता है, जिसमें कोई दस्तावेज़ नहीं हो सकता है (सिद्धांत में) या एक से अधिक दस्तावेज़। कोई दस्तावेज़ों को पंक्तियों और संग्रहों की तुलना तालिकाओं से कर सकता है (यहाँ तालिकाओं और पंक्तियों का संबंध रिलेशनल डेटाबेस मैनेजमेंट सिस्टम - RDBMS से है)।

लेकिन, RDBMS में, इन परिभाषाओं को स्कीमा कहते हुए, स्तंभों को परिभाषित करना एक तालिका में अभिलेखों को संग्रहीत करने के लिए एक शर्त है। हालाँकि, एक उपन्यास विशेषता के रूप में, अरंगबोबे स्कीमा-कम है - यह निर्दिष्ट करने का कोई प्राथमिक कारण नहीं है कि दस्तावेज़ में क्या विशेषताएँ होंगी।

और RDBMS के विपरीत, प्रत्येक दस्तावेज़ को दूसरे दस्तावेज़ से पूरी तरह से अलग तरीके से संरचित किया जा सकता है। इन दस्तावेजों को एक एकल संग्रह में एक साथ बचाया जा सकता है। व्यावहारिक रूप से, संग्रह में दस्तावेजों के बीच आम विशेषताएं मौजूद हो सकती हैं, हालांकि डेटाबेस सिस्टम, यानी, अरेंजबीडीबी खुद को एक विशेष डेटा संरचना से नहीं बांधता है।

अब हम ArangoDB को समझने की कोशिश करेंगे [graph data model], जिसमें दो प्रकार के संग्रह की आवश्यकता होती है - पहला है दस्तावेज़ संग्रह (समूह-सिद्धांत भाषा में शीर्षकों के संग्रह के रूप में जाना जाता है), दूसरा किनारा संग्रह है। इन दो प्रकारों के बीच एक सूक्ष्म अंतर है। एज संग्रह भी दस्तावेजों को संग्रहीत करते हैं, लेकिन वे दो अद्वितीय विशेषताओं को शामिल करके विशेषता हैं,_from तथा _toदस्तावेजों के बीच संबंध बनाने के लिए। व्यवहार में, एक दस्तावेज़ (पढ़ा हुआ किनारा) दो दस्तावेजों को जोड़ता है (लंबवत पढ़ें), दोनों को उनके संबंधित संग्रह में संग्रहीत किया जाता है। यह आर्किटेक्चर एक लेबल वाले, निर्देशित ग्राफ के ग्राफ-सिद्धांत की अवधारणा से लिया गया है, जिसमें उन किनारों को छोड़कर जो न केवल लेबल हो सकते हैं, बल्कि अपने आप में दस्तावेज़ की तरह एक संपूर्ण JSON हो सकते हैं।

ताजा आंकड़ों की गणना करने के लिए, दस्तावेजों को हटा दें या उनमें हेरफेर करें, प्रश्नों का उपयोग किया जाता है, जो दिए गए मानदंडों के अनुसार दस्तावेजों का चयन या फ़िल्टर करते हैं। या तो "उदाहरण क्वेरी" के रूप में सरल या "जॉइन" के रूप में जटिल होने के नाते, प्रश्न AQL - ArangoDB क्वेरी भाषा में कोडित हैं।

इस अध्याय में, हम ArangoDB में विभिन्न डेटाबेस विधियों पर चर्चा करेंगे।

शुरू करने के लिए, आइए हम डेटाबेस के गुण प्राप्त करें -

  • Name
  • ID
  • Path

सबसे पहले, हम आरंगोश का आह्वान करते हैं। एक बार, आरंगोश को आमंत्रित किया जाता है, हम अब तक बनाए गए डेटाबेस की सूची देंगे -

आरंगोश को आमंत्रित करने के लिए हम निम्नलिखित लाइन ऑफ़ कोड का उपयोग करेंगे -

127.0.0.1:8529@_system> db._databases()

उत्पादन

[
   "_system",
   "song_collection"
]

हम दो डेटाबेस देखते हैं, एक _system डिफ़ॉल्ट रूप से बनाया गया है, और दूसरा song_collection जो हमने बनाया है।

अब कोड की निम्नलिखित लाइन के साथ हमें song_collection डेटाबेस में शिफ्ट करें -

127.0.0.1:8529@_system> db._useDatabase("song_collection")

उत्पादन

true
127.0.0.1:8529@song_collection>

हम अपने song_collection डेटाबेस के गुणों का पता लगाएंगे।

नाम खोजने के लिए

हम नाम खोजने के लिए कोड की निम्न पंक्ति का उपयोग करेंगे।

127.0.0.1:8529@song_collection> db._name()

उत्पादन

song_collection

आईडी खोजने के लिए -

हम आईडी खोजने के लिए कोड की निम्नलिखित लाइन का उपयोग करेंगे।

song_collection

उत्पादन

4838

रास्ता खोजने के लिए -

हम रास्ता खोजने के लिए कोड की निम्न पंक्ति का उपयोग करेंगे।

127.0.0.1:8529@song_collection> db._path()

उत्पादन

/var/lib/arangodb3/databases/database-4838

आइए अब हम जाँचते हैं कि हम कोड के निम्नलिखित लाइन का उपयोग करके सिस्टम डेटाबेस में हैं या नहीं -

127.0.0.1:8529@song_collection&t; db._isSystem()

उत्पादन

false

इसका मतलब है कि हम सिस्टम डेटाबेस में नहीं हैं (जैसा कि हमने बनाया है और song_collection में स्थानांतरित कर दिया है)। निम्नलिखित स्क्रीनशॉट आपको इसे समझने में मदद करेगा।

एक विशेष संग्रह प्राप्त करने के लिए, गीत कहें -

हम एक विशेष संग्रह पाने के लिए कोड की निम्नलिखित पंक्ति का उपयोग करेंगे।

127.0.0.1:8529@song_collection> db._collection("songs")

उत्पादन

[ArangoCollection 4890, "songs" (type document, status loaded)]

कोड की लाइन एक एकल संग्रह लौटाती है।

आइए हम अपने बाद के अध्यायों के साथ डेटाबेस ऑपरेशंस की अनिवार्यता पर चलते हैं।

इस अध्याय में, हम आरंगोश के साथ विभिन्न कार्यों के बारे में जानेंगे।

आरंगोश के साथ संभावित संचालन निम्नलिखित हैं -

  • दस्तावेज़ संग्रह बनाना
  • दस्तावेज़ बनाना
  • दस्तावेज़ पढ़ना
  • अद्यतन दस्तावेज़

एक नया डेटाबेस बनाकर शुरू करते हैं। एक नया डेटाबेस बनाने के लिए हम निम्नलिखित लाइन ऑफ़ कोड का उपयोग करेंगे -

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

हमारे पिछले अध्याय में, हमने सीखा कि कमांड लाइन आरंगोश के साथ दस्तावेजों पर विभिन्न ऑपरेशन कैसे करें। अब हम सीखेंगे कि वेब इंटरफेस का उपयोग करके समान संचालन कैसे करें। आरंभ करने के लिए, निम्न पता - http: // your_server_ip: 8529 / _db / song_collection / _admin / aardvark / index.html # अपने ब्राउज़र के एड्रेस बार में लॉगिन करें। आपको निम्न लॉगिन पृष्ठ पर निर्देशित किया जाएगा।

अब, उपयोगकर्ता नाम और पासवर्ड दर्ज करें।

यदि यह सफल है, तो निम्न स्क्रीन दिखाई देती है। डेटाबेस पर काम करने के लिए हमें एक विकल्प बनाने की जरूरत है,_systemडेटाबेस एक डिफ़ॉल्ट है। हमें चुनने दोsong_collection डेटाबेस, और हरे टैब पर क्लिक करें -

एक संग्रह बनाना

इस अनुभाग में, हम सीखेंगे कि एक संग्रह कैसे बनाया जाए। शीर्ष पर नेविगेशन बार में संग्रह टैब दबाएं।

हमारी कमांड लाइन जोड़ा गाने संग्रह दिखाई दे रहे हैं। उस पर क्लिक करने से प्रविष्टियाँ दिखाई देंगी। अब हम एक जोड़ देंगेartists’वेब इंटरफेस का उपयोग कर संग्रह। संग्रहsongsजो हमने आरंगोश के साथ बनाया है वह पहले से ही है। नाम फ़ील्ड में, लिखेंartists में New Collectionदिखाई देने वाला डायलॉग बॉक्स। उन्नत विकल्पों को सुरक्षित रूप से अनदेखा किया जा सकता है और डिफ़ॉल्ट संग्रह प्रकार, अर्थात दस्तावेज़, ठीक है।

सहेजें बटन पर क्लिक करने से अंत में संग्रह बन जाएगा, और अब इस पृष्ठ पर दो संग्रह दिखाई देंगे।

दस्तावेजों के साथ नए बनाए गए संग्रह को भरना

क्लिक करने पर आपको एक खाली संग्रह प्रस्तुत किया जाएगा artists संग्रह -

दस्तावेज़ जोड़ने के लिए, आपको ऊपरी दाएं कोने में स्थित + चिह्न पर क्लिक करना होगा। जब आप एक के लिए कहा जाए_key, दर्ज Affable_Balding कुंजी के रूप में।

अब, दस्तावेज़ की विशेषताओं को जोड़ने और संपादित करने के लिए एक फ़ॉर्म दिखाई देगा। विशेषताएँ जोड़ने के दो तरीके हैं:Graphical तथा Tree। चित्रमय तरीका सहज लेकिन धीमा है, इसलिए, हम स्विच करेंगेCode इसे चुनने के लिए ट्री ड्रॉपडाउन मेनू का उपयोग करके देखें -

प्रक्रिया को आसान बनाने के लिए, हमने JSON प्रारूप में एक नमूना डेटा बनाया है, जिसे आप कॉपी कर सकते हैं और फिर क्वेरी संपादक क्षेत्र में पेस्ट कर सकते हैं -

{"कलाकार": "जॉनी मर्सर", "शीर्षक": "अफेक्टेबल बैल्डिंग मी", "संगीतकार": "रॉबर्ट एम्मेट डोलन", "वर्ष": 1950}

(नोट: केवल एक जोड़ी घुंघराले ब्रेसिज़ का उपयोग किया जाना चाहिए; नीचे स्क्रीनशॉट देखें)

आप देख सकते हैं कि हमने कोड व्यू मोड में कुंजियों और मानों को भी उद्धृत किया है। अब, क्लिक करेंSave। सफल होने पर, पृष्ठ पर हरे रंग की फ्लैश दिखाई देती है।

कैसे पढ़ें डॉक्युमेंट्स

दस्तावेज़ पढ़ने के लिए, संग्रह पृष्ठ पर वापस जाएं।

जब कोई क्लिक करता है artist संग्रह, एक नई प्रविष्टि दिखाई देती है।

दस्तावेज़ कैसे अद्यतन करें

दस्तावेज़ में प्रविष्टियों को संपादित करना सरल है; आपको बस उस पंक्ति पर क्लिक करने की आवश्यकता है जिसे आप दस्तावेज़ अवलोकन में संपादित करना चाहते हैं। यहां नए दस्तावेज़ बनाते समय फिर से उसी क्वेरी संपादक को प्रस्तुत किया जाएगा।

दस्तावेज निकालना

आप '-' आइकन दबाकर दस्तावेजों को हटा सकते हैं। हर दस्तावेज़ पंक्ति में अंत में यह चिन्ह होता है। यह आपको असुरक्षित विलोपन से बचने के लिए पुष्टि करने के लिए प्रेरित करेगा।

इसके अलावा, एक विशेष संग्रह के लिए, दस्तावेज़ों को फ़िल्टर करने, अनुक्रमणिका को प्रबंधित करने और डेटा आयात करने जैसे अन्य संचालन भी मौजूद हैं Collections Overview पृष्ठ।

हमारे बाद के अध्याय में, हम वेब इंटरफेस की एक महत्वपूर्ण विशेषता पर चर्चा करेंगे, अर्थात, AQL क्वेरी संपादक।

इस अध्याय में, हम चर्चा करेंगे कि डेटा को AQL के साथ कैसे क्वेरी करें। हम पहले ही अपने पिछले अध्यायों में चर्चा कर चुके हैं कि ArangoDB ने अपनी स्वयं की क्वेरी भाषा विकसित की है और यह AQL नाम से जाती है।

आइए अब AQL के साथ बातचीत शुरू करते हैं। जैसा कि नीचे दी गई छवि में दिखाया गया है, वेब इंटरफेस में, दबाएंAQL Editorनेविगेशन बार के शीर्ष पर रखा गया टैब। एक रिक्त क्वेरी संपादक दिखाई देगा।

जब जरूरत हो, तो आप परिणाम दृश्य से संपादक को स्विच कर सकते हैं और इसके विपरीत, ऊपरी दाएँ कोने में क्वेरी या परिणाम टैब पर क्लिक करके जैसा कि नीचे की छवि में दिखाया गया है -

अन्य बातों के अलावा, संपादक में सिंटैक्स हाइलाइटिंग, पूर्ववत / फिर से कार्यक्षमता, और क्वेरी सेविंग है। एक विस्तृत संदर्भ के लिए, कोई आधिकारिक दस्तावेज देख सकता है। हम AQL क्वेरी संपादक की कुछ बुनियादी और आमतौर पर उपयोग की जाने वाली विशेषताओं को उजागर करेंगे।

AQL बुनियादी बातों

AQL में, एक क्वेरी प्राप्त करने के लिए अंतिम परिणाम का प्रतिनिधित्व करता है, लेकिन वह प्रक्रिया नहीं जिसके माध्यम से अंतिम परिणाम प्राप्त किया जाना है। इस सुविधा को आमतौर पर भाषा की घोषित संपत्ति के रूप में जाना जाता है। इसके अलावा, AQL डेटा को संशोधित करने के साथ-साथ क्वेरी भी कर सकता है, और इस प्रकार दोनों प्रक्रियाओं को मिलाकर जटिल प्रश्न बनाए जा सकते हैं।

कृपया ध्यान दें कि AQL पूरी तरह से ACID-अनुरूप है। प्रश्नों को पढ़ना या संशोधित करना या तो पूरी तरह से समाप्त होगा या नहीं। यहां तक ​​कि एक दस्तावेज़ के डेटा को पढ़ना डेटा की एक सुसंगत इकाई के साथ समाप्त होगा।

हम दो नए जोड़ते हैं songsगीतों के संग्रह को हम पहले ही बना चुके हैं। टाइप करने के बजाय, आप निम्नलिखित क्वेरी को कॉपी कर सकते हैं, और इसे AQL संपादक में पेस्ट कर सकते हैं -

FOR song IN [
   {
      title: "Air-Minded Executive", lyricist: "Johnny Mercer",
      composer: "Bernie Hanighen", Year: 1940, _key: "Air-Minded"
   },
   
   {
      title: "All Mucked Up", lyricist: "Johnny Mercer", composer:
      "Andre Previn", Year: 1974, _key: "All_Mucked"
   }
]
INSERT song IN songs

निचले बाएँ पर स्थित निष्पादन बटन दबाएँ।

इसमें दो नए दस्तावेज़ लिखेंगे songs संग्रह।

यह प्रश्न बताता है कि फोर लूप AQL में कैसे काम करता है; यह JSON एन्कोडेड दस्तावेज़ों की सूची पर आधारित है, जो संग्रह में प्रत्येक दस्तावेज़ पर कोड किए गए संचालन का प्रदर्शन कर रहा है। अलग-अलग ऑपरेशन नई संरचनाएं बना सकते हैं, फ़िल्टर कर सकते हैं, दस्तावेजों का चयन कर सकते हैं, संशोधित कर सकते हैं या डेटाबेस में दस्तावेज़ डाल सकते हैं (तात्कालिक उदाहरण देखें)। संक्षेप में, AQL CRUD संचालन को कुशलतापूर्वक कर सकता है।

हमारे डेटाबेस में सभी गीतों को खोजने के लिए, हमें एक बार फिर से निम्नलिखित क्वेरी को रन करना चाहिए, एक के बराबर SELECT * FROM songs SQL- प्रकार डेटाबेस के (क्योंकि संपादक अंतिम क्वेरी को याद करता है, दबाएं *New* संपादक को साफ करने के लिए बटन) -

FOR song IN songs
RETURN song

परिणाम सेट में अब तक सहेजे गए गीतों की सूची दिखाई जाएगी songs नीचे स्क्रीनशॉट में संग्रह दिखाया गया है।

जैसे संचालन FILTER, SORT तथा LIMIT में जोड़ा जा सकता है For loop शरीर को संकीर्ण करने और परिणाम का आदेश देने के लिए।

FOR song IN songs
FILTER song.Year > 1940
RETURN song

उपरोक्त क्वेरी वर्ष 1940 के बाद बने गीतों को रिजल्ट टैब में देगी (नीचे दी गई छवि देखें)।

इस उदाहरण में दस्तावेज़ कुंजी का उपयोग किया जाता है, लेकिन किसी अन्य विशेषता को फ़िल्टरिंग के लिए एक समकक्ष के रूप में भी इस्तेमाल किया जा सकता है। चूंकि दस्तावेज़ कुंजी अद्वितीय होने की गारंटी है, इसलिए एक से अधिक दस्तावेज़ इस फ़िल्टर से मेल नहीं खाते। अन्य विशेषताओं के लिए ऐसा नहीं हो सकता है। सक्रिय उपयोगकर्ताओं के एक सबसेट को वापस करने के लिए (स्थिति नामक एक विशेषता द्वारा निर्धारित), आरोही क्रम में नाम से क्रमबद्ध, हम निम्नलिखित सिंटैक्स का उपयोग करते हैं -

FOR song IN songs
FILTER song.Year > 1940
SORT song.composer
RETURN song
LIMIT 2

हमने जानबूझकर इस उदाहरण को शामिल किया है। यहां, हम AQL द्वारा लाल में हाइलाइट किए गए क्वेरी सिंटैक्स त्रुटि संदेश का निरीक्षण करते हैं। यह सिंटैक्स त्रुटियों को उजागर करता है और नीचे दिए गए स्क्रीनशॉट में दिखाए अनुसार आपके प्रश्नों को डीबग करने में सहायक है।

आइए अब हम सही क्वेरी चलाते हैं (सुधार पर ध्यान दें) -

FOR song IN songs
FILTER song.Year > 1940
SORT song.composer
LIMIT 2
RETURN song

AQL में जटिल क्वेरी

AQL सभी समर्थित डेटा प्रकारों के लिए कई कार्यों से सुसज्जित है। एक क्वेरी के भीतर परिवर्तनीय असाइनमेंट बहुत जटिल नेस्टेड निर्माण करने की अनुमति देता है। इस तरह से डेटा-सघन संचालन बैकएंड पर क्लाइंट (जैसे ब्राउज़र) की तुलना में डेटा के करीब जाता है। इसे समझने के लिए, आइए हम सबसे पहले गाने में मनमानी अवधि (लंबाई) जोड़ें।

आइए पहले फ़ंक्शन के साथ शुरू करें, यानी, अपडेट फ़ंक्शन -

UPDATE { _key: "All_Mucked" }
WITH { length: 180 }
IN songs

हम देख सकते हैं कि एक दस्तावेज़ को उपरोक्त स्क्रीनशॉट में दिखाया गया है।

आइए अब हम अन्य दस्तावेजों (गीतों) को भी अपडेट करते हैं।

UPDATE { _key: "Affable_Balding" }
WITH { length: 200 }
IN songs

अब हम देख सकते हैं कि हमारे सभी गीतों में एक नई विशेषता है length -

FOR song IN songs
RETURN song

उत्पादन

[
   {
      "_key": "Air-Minded",
      "_id": "songs/Air-Minded",
      "_rev": "_VkC5lbS---",
      "title": "Air-Minded Executive",
      "lyricist": "Johnny Mercer",
      "composer": "Bernie Hanighen",
      "Year": 1940,
      "length": 210
   },
   
   {
      "_key": "Affable_Balding",
      "_id": "songs/Affable_Balding",
      "_rev": "_VkC4eM2---",
      "title": "Affable Balding Me",
      "lyricist": "Johnny Mercer",
      "composer": "Robert Emmett Dolan",
      "Year": 1950,
      "length": 200
   },
   
   {
      "_key": "All_Mucked",
      "_id": "songs/All_Mucked",
      "_rev": "_Vjah9Pu---",
      "title": "All Mucked Up",
      "lyricist": "Johnny Mercer",
      "composer": "Andre Previn",
      "Year": 1974,
      "length": 180
   },
   
   {
      "_key": "Accentchuate_The",
      "_id": "songs/Accentchuate_The",
      "_rev": "_VkC3WzW---",
      "title": "Accentchuate The Politics",
      "lyricist": "Johnny Mercer",
      "composer": "Harold Arlen",
      "Year": 1944,
      "length": 190
   }
]

AQL के अन्य कीवर्ड जैसे LET, FILTER, SORT, आदि के उपयोग को स्पष्ट करने के लिए, हम अब इस गीत के स्वर को प्रारूपित करते हैं mm:ss प्रारूप।

सवाल

FOR song IN songs
FILTER song.length > 150
LET seconds = song.length % 60
LET minutes = FLOOR(song.length / 60)
SORT song.composer
RETURN
{
   Title: song.title, 
   Composer: song.composer, 
   Duration: CONCAT_SEPARATOR(':',minutes, seconds) 
}

इस बार हम अवधि के साथ गीत का शीर्षक वापस करेंगे। Return फ़ंक्शन आपको प्रत्येक इनपुट दस्तावेज़ पर लौटने के लिए एक नया JSON ऑब्जेक्ट बनाने देता है।

अब हम AQL डेटाबेस के 'जॉइन्स' फीचर के बारे में बात करेंगे।

हमें एक संग्रह बनाकर शुरू करते हैं composer_dob। इसके अलावा, हम निम्नलिखित दस्तावेजों को जन्म बॉक्स में निम्नलिखित क्वेरी चलाकर रचनाकारों के जन्म की तारीख के साथ चार दस्तावेज बनाएंगे -

FOR dob IN [
   {composer: "Bernie Hanighen", Year: 1909}
   ,
   {composer: "Robert Emmett Dolan", Year: 1922}
   ,
   {composer: "Andre Previn", Year: 1943}
   ,
   {composer: "Harold Arlen", Year: 1910}
]
INSERT dob in composer_dob

एसक्यूएल के साथ समानता को उजागर करने के लिए, हम AQL में एक नेस्टेड फॉर-लूप क्वेरी पेश करते हैं, REPLACE ऑपरेशन के लिए अग्रणी है, जो सभी संगीतकार के डॉब पर और फिर सभी संबंधित गानों पर एक नया दस्तावेज़ बनाते हुए, इनर लूप में पहले से प्रदर्शित होता है गुण song_with_composer_key के स्थान पर song विशेषता।

यहाँ क्वेरी है -

FOR s IN songs
FOR c IN composer_dob
FILTER s.composer == c.composer

LET song_with_composer_key = MERGE(
   UNSET(s, 'composer'),
   {composer_key:c._key}
)
REPLACE s with song_with_composer_key IN songs

अब हम क्वेरी चलाते हैं FOR song IN songs RETURN song फिर से देखने के लिए कि गीत संग्रह कैसे बदल गया है।

उत्पादन

[
   {
      "_key": "Air-Minded",
      "_id": "songs/Air-Minded",
      "_rev": "_Vk8kFoK---",
      "Year": 1940,
      "composer_key": "5501",
      "length": 210,
      "lyricist": "Johnny Mercer",
      "title": "Air-Minded Executive"
   },
   
   {
      "_key": "Affable_Balding",
      "_id": "songs/Affable_Balding",
      "_rev": "_Vk8kFoK--_",
      "Year": 1950,
      "composer_key": "5505",
      "length": 200,
      "lyricist": "Johnny Mercer",
      "title": "Affable Balding Me"
   },
   
   {
      "_key": "All_Mucked",
      "_id": "songs/All_Mucked",
      "_rev": "_Vk8kFoK--A",
      "Year": 1974,
      "composer_key": "5507",
      "length": 180,
      "lyricist": "Johnny Mercer",
      "title": "All Mucked Up"
   },
   
   {
      "_key": "Accentchuate_The",
      "_id": "songs/Accentchuate_The",
      "_rev": "_Vk8kFoK--B",
      "Year": 1944,
      "composer_key": "5509",
      "length": 190,
      "lyricist": "Johnny Mercer",
      "title": "Accentchuate The Politics"
   }
]

उपरोक्त क्वेरी डेटा माइग्रेशन प्रक्रिया को पूरा करती है, को जोड़ते हुए composer_key प्रत्येक गीत के लिए।

अब अगली क्वेरी फिर से नेस्टेड-लूप क्वेरी है, लेकिन इस बार ज्वाइन ऑपरेशन में अग्रणी, प्रत्येक गीत के लिए संबद्ध संगीतकार का नाम (`कंपोज़र_की` की मदद से उठाते हुए) जोड़ते हुए -

FOR s IN songs
FOR c IN composer_dob
FILTER c._key == s.composer_key
RETURN MERGE(s,
{ composer: c.composer }
)

उत्पादन

[
   {
      "Year": 1940,
      "_id": "songs/Air-Minded",
      "_key": "Air-Minded",
      "_rev": "_Vk8kFoK---",
      "composer_key": "5501",
      "length": 210,
      "lyricist": "Johnny Mercer",
      "title": "Air-Minded Executive",
      "composer": "Bernie Hanighen"
   },
   
   {
      "Year": 1950,
      "_id": "songs/Affable_Balding",
      "_key": "Affable_Balding",
      "_rev": "_Vk8kFoK--_",
      "composer_key": "5505",
      "length": 200,
      "lyricist": "Johnny Mercer",
      "title": "Affable Balding Me",
      "composer": "Robert Emmett Dolan"
   },

   {
      "Year": 1974,
      "_id": "songs/All_Mucked",
      "_key": "All_Mucked",
      "_rev": "_Vk8kFoK--A",
      "composer_key": "5507",
      "length": 180,
      "lyricist": "Johnny Mercer",
      "title": "All Mucked Up",
      "composer": "Andre Previn"
   },

   {
      "Year": 1944,
      "_id": "songs/Accentchuate_The",
      "_key": "Accentchuate_The",
      "_rev": "_Vk8kFoK--B",
      "composer_key": "5509",
      "length": 190,
      "lyricist": "Johnny Mercer",
      "title": "Accentchuate The Politics",
      "composer": "Harold Arlen"
   }
]

इस अध्याय में, हम कुछ AQL उदाहरण क्वेरीज़ पर विचार करेंगे Actors and Moviesडेटाबेस। ये प्रश्न ग्राफ पर आधारित हैं।

मुसीबत

अभिनेताओं के संग्रह और फिल्मों के संग्रह को देखते हुए, और नीचे दिखाए गए शीर्ष को जोड़ने के लिए एक actIn किनारों का संग्रह (एक वर्ष की संपत्ति के साथ) -

[Actor] <- act in -> [Movie]

हम कैसे प्राप्त करते हैं -

  • "मूवी 1" या "मूवी 2" में अभिनय करने वाले सभी कलाकार?
  • सभी अभिनेता जिन्होंने "मूवी 1" और "मूवी 2" दोनों में अभिनय किया?
  • "अभिनेता 1" और "अभिनेता 2" के बीच सभी आम फिल्में?
  • 3 या अधिक फिल्मों में अभिनय करने वाले सभी कलाकार?
  • सभी फिल्में जहां ठीक 6 अभिनेताओं ने अभिनय किया?
  • फिल्म द्वारा अभिनेताओं की संख्या?
  • अभिनेता द्वारा फिल्मों की संख्या?
  • अभिनेता द्वारा 2005 और 2010 के बीच फिल्मों की संख्या कितनी थी?

उपाय

उपरोक्त प्रश्नों के उत्तर को हल करने और प्राप्त करने की प्रक्रिया के दौरान, हम डेटासेट बनाने और उस पर क्वेरी चलाने के लिए आरंगोश का उपयोग करेंगे। सभी AQL प्रश्न तार हैं और बस आरंगोश के बजाय आपके पसंदीदा ड्राइवर पर कॉपी किए जा सकते हैं।

आरंगोश में टेस्ट डेटासट बनाकर शुरू करते हैं। सबसे पहले, इस फ़ाइल को डाउनलोड करें -

# wget -O dataset.js
https://drive.google.com/file/d/0B4WLtBDZu_QWMWZYZ3pYMEdqajA/view?usp=sharing

उत्पादन

...
HTTP request sent, awaiting response... 200 OK
Length: unspecified [text/html]
Saving to: ‘dataset.js’
dataset.js [ <=> ] 115.14K --.-KB/s in 0.01s
2017-09-17 14:19:12 (11.1 MB/s) - ‘dataset.js’ saved [117907]

आप ऊपर दिए गए आउटपुट में देख सकते हैं कि हमने एक जावास्क्रिप्ट फाइल डाउनलोड की है dataset.js.इस फ़ाइल में डेटाबेस में डेटासेट बनाने के लिए आरंगोश कमांड हैं। आदेशों को एक-एक करके कॉपी करने और चिपकाने के बजाय, हम इसका उपयोग करेंगे--javascript.executeअरंगोश पर विकल्प गैर-अंतःक्रियात्मक रूप से कई आदेशों को निष्पादित करने के लिए। इसे जीवन रक्षक आदेश मानें!

अब शेल पर निम्नलिखित कमांड निष्पादित करें -

$ arangosh --javascript.execute dataset.js

जब आप उपरोक्त स्क्रीनशॉट में देख सकते हैं तो पासवर्ड की आपूर्ति करें। अब हमने डेटा सहेज लिया है, इसलिए हम इस अध्याय की शुरुआत में उठाए गए विशिष्ट प्रश्नों के उत्तर देने के लिए AQL प्रश्नों का निर्माण करेंगे।

पहला प्रश्न

आइए हम पहला सवाल करें: All actors who acted in "movie1" OR "movie2"। मान लीजिए, हम उन सभी अभिनेताओं के नाम ढूंढना चाहते हैं जिन्होंने "TheMatrix" या "TheDevilsAdvocate" में अभिनय किया -

हम अभिनेताओं के नाम पाने के लिए एक समय में एक फिल्म के साथ शुरू करेंगे -

127.0.0.1:8529@_system> db._query("FOR x IN ANY 'movies/TheMatrix' actsIn
OPTIONS {bfs: true, uniqueVertices: 'global'} RETURN x._id").toArray();

उत्पादन

हम निम्नलिखित उत्पादन प्राप्त करेंगे -

[
   "actors/Hugo",
   "actors/Emil",
   "actors/Carrie",
   "actors/Keanu",
   "actors/Laurence"
]

अब हम दो NEIGHBORS प्रश्नों का एक UNION_DISTINCT बना रहे हैं, जो समाधान होगा -

127.0.0.1:8529@_system> db._query("FOR x IN UNION_DISTINCT ((FOR y IN ANY
'movies/TheMatrix' actsIn OPTIONS {bfs: true, uniqueVertices: 'global'} RETURN
y._id), (FOR y IN ANY 'movies/TheDevilsAdvocate' actsIn OPTIONS {bfs: true,
uniqueVertices: 'global'} RETURN y._id)) RETURN x").toArray();

उत्पादन

[
   "actors/Charlize",
   "actors/Al",
   "actors/Laurence",
   "actors/Keanu",
   "actors/Carrie",
   "actors/Emil",
   "actors/Hugo"
]

दूसरा सवाल

चलिए अब दूसरे प्रश्न पर विचार करते हैं: All actors who acted in both "movie1" AND "movie2"। यह ऊपर दिए गए प्रश्न के लगभग समान है। लेकिन इस बार हमें एक यूनिअन में दिलचस्पी नहीं है बल्कि एक इंटरेक्शन में है -

127.0.0.1:8529@_system> db._query("FOR x IN INTERSECTION ((FOR y IN ANY
'movies/TheMatrix' actsIn OPTIONS {bfs: true, uniqueVertices: 'global'} RETURN
y._id), (FOR y IN ANY 'movies/TheDevilsAdvocate' actsIn OPTIONS {bfs: true,
uniqueVertices: 'global'} RETURN y._id)) RETURN x").toArray();

उत्पादन

हम निम्नलिखित उत्पादन प्राप्त करेंगे -

[
   "actors/Keanu"
]

तीसरा प्रश्न

आइए अब तीसरे प्रश्न पर विचार करें: All common movies between "actor1" and "actor2"। यह वास्तव में मूवी 1 और मूवी 2 में आम अभिनेताओं के बारे में प्रश्न के समान है। हमें बस शुरुआती सिरों को बदलना होगा। एक उदाहरण के रूप में, आइए हम सभी फिल्में खोजें जहां ह्यूगो वीविंग ("ह्यूगो") और कीनू रीव्स सह-अभिनीत हैं -

127.0.0.1:8529@_system> db._query(
   "FOR x IN INTERSECTION (
      (
         FOR y IN ANY 'actors/Hugo' actsIn OPTIONS 
         {bfs: true, uniqueVertices: 'global'}
          RETURN y._id
      ),
      
      (
         FOR y IN ANY 'actors/Keanu' actsIn OPTIONS 
         {bfs: true, uniqueVertices:'global'} RETURN y._id
      )
   ) 
   RETURN x").toArray();

उत्पादन

हम निम्नलिखित उत्पादन प्राप्त करेंगे -

[
   "movies/TheMatrixReloaded",
   "movies/TheMatrixRevolutions",
   "movies/TheMatrix"
]

चौथा प्रश्न

अब हम चौथे प्रश्न पर विचार करते हैं। All actors who acted in 3 or more movies। यह सवाल अलग है; हम यहां पड़ोसी फ़ंक्शन का उपयोग नहीं कर सकते। इसके बजाय हम समूहीकरण के लिए AQL के एज-इंडेक्स और COLLECT स्टेटमेंट का उपयोग करेंगे। मूल विचार सभी किनारों को उनके द्वारा समूहित करना हैstartVertex(जो इस डेटासेट में हमेशा अभिनेता होता है)। फिर हम परिणाम से 3 फिल्मों से कम वाले सभी अभिनेताओं को हटा देते हैं क्योंकि हमने उन फिल्मों को शामिल किया है जिनमें एक अभिनेता ने कितनी फिल्मों में अभिनय किया है -

127.0.0.1:8529@_system> db._query("FOR x IN actsIn COLLECT actor = x._from WITH
COUNT INTO counter FILTER counter >= 3 RETURN {actor: actor, movies:
counter}"). toArray()

उत्पादन

[
   {
      "actor" : "actors/Carrie",
      "movies" : 3
   },
   
   {
      "actor" : "actors/CubaG",
      "movies" : 4
   },

   {
      "actor" : "actors/Hugo",
      "movies" : 3
   },

   {
      "actor" : "actors/Keanu",
      "movies" : 4
   },

   {
      "actor" : "actors/Laurence",
      "movies" : 3
   },

   {
      "actor" : "actors/MegR",
      "movies" : 5
   },

   {
      "actor" : "actors/TomC",
      "movies" : 3
   },
   
   {
      "actor" : "actors/TomH",
      "movies" : 3
   }
]

शेष प्रश्नों के लिए, हम क्वेरी गठन पर चर्चा करेंगे, और केवल प्रश्न प्रदान करेंगे। पाठक को आरंगोश टर्मिनल पर क्वेरी को स्वयं चलाना चाहिए।

पाँचवाँ प्रश्न

आइए अब पांचवें प्रश्न पर विचार करें: All movies where exactly 6 actors acted in। क्वेरी में पहले जैसा ही विचार है, लेकिन समानता फ़िल्टर के साथ है। हालांकि, अब हमें अभिनेता के बजाय फिल्म की आवश्यकता है, इसलिए हम वापसी करते हैं_to attribute -

db._query("FOR x IN actsIn COLLECT movie = x._to WITH COUNT INTO counter FILTER
counter == 6 RETURN movie").toArray()

फिल्म द्वारा अभिनेताओं की संख्या?

हम अपने डेटासेट में याद करते हैं _to किनारे पर फिल्म से मेल खाती है, इसलिए हम गिनते हैं कि कितनी बार समान है _toप्रकट होता है। यह अभिनेताओं की संख्या है। क्वेरी पहले के लगभग समान है लेकिनwithout the FILTER after COLLECT -

db._query("FOR x IN actsIn COLLECT movie = x._to WITH COUNT INTO counter RETURN
{movie: movie, actors: counter}").toArray()

छठा प्रश्न

आइए अब छठे प्रश्न पर विचार करें: The number of movies by an actor

जिस तरह से हमने अपने उपरोक्त प्रश्नों का समाधान पाया, उससे आपको इस प्रश्न का हल भी मिल जाएगा।

db._query("FOR x IN actsIn COLLECT actor = x._from WITH COUNT INTO counter
RETURN {actor: actor, movies: counter}").toArray()

इस अध्याय में, हम ArangoDB को तैनात करने के लिए विभिन्न संभावनाओं का वर्णन करेंगे।

तैनाती: एकल उदाहरण

हमने पहले ही सीखा है कि हमारे पिछले अध्यायों में से एक में लिनक्स (उबंटू) के एकल उदाहरण को कैसे तैनात किया जाए। आइए अब देखते हैं कि डोकर का उपयोग करके तैनाती कैसे करें।

तैनाती: डॉकटर

डॉकटर का उपयोग करते हुए तैनाती के लिए, हम अपनी मशीन पर डॉकर स्थापित करेंगे। डोकर के बारे में अधिक जानकारी के लिए, पर हमारे ट्यूटोरियल देखें डोकर ।

एक बार डॉकर इंस्टॉल हो जाने के बाद, आप निम्न कमांड का उपयोग कर सकते हैं -

docker run -e ARANGO_RANDOM_ROOT_PASSWORD = 1 -d --name agdb-foo -d
arangodb/arangodb

यह पहचान नाम के साथ ArangoDB का डॉकर उदाहरण बनाएगा और लॉन्च करेगा agdbfoo एक डॉकर पृष्ठभूमि प्रक्रिया के रूप में।

साथ ही टर्मिनल प्रक्रिया पहचानकर्ता को प्रिंट करेगा।

डिफ़ॉल्ट रूप से, पोर्ट 8529 अनुरोधों को सुनने के लिए ArangoDB के लिए आरक्षित है। इसके अलावा यह पोर्ट स्वचालित रूप से सभी डॉकटर एप्लिकेशन कंटेनरों के लिए उपलब्ध है जिसे आपने लिंक किया होगा।