ArangoDB - AQL उदाहरण क्वेरी

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

मुसीबत

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

[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()