Neo4j - त्वरित गाइड
Neo4j दुनिया का प्रमुख खुला स्रोत ग्राफ डेटाबेस है जिसे जावा तकनीक का उपयोग करके विकसित किया गया है। यह अत्यधिक स्केलेबल और स्कीमा मुक्त (NoSQL) है।
एक ग्राफ़ डेटाबेस क्या है?
एक ग्राफ वस्तुओं के एक सेट का एक चित्रमय प्रतिनिधित्व है जहां कुछ जोड़े वस्तुओं के लिंक से जुड़े होते हैं। यह दो तत्वों से बना है - नोड्स (कोने) और रिश्ते (किनारों)।
ग्राफ डेटाबेस एक डेटाबेस है जिसका उपयोग ग्राफ के रूप में डेटा को मॉडल करने के लिए किया जाता है। यहाँ, ग्राफ़ के नोड्स संस्थाओं को दर्शाते हैं जबकि रिश्ते इन नोड्स के जुड़ाव को दर्शाते हैं।
लोकप्रिय ग्राफ डेटाबेस
Neo4j एक लोकप्रिय ग्राफ डेटाबेस है। अन्य ग्राफ डेटाबेस ओरेकल नूएसक्यूएल डेटाबेस, ओरिएंटडीबी, हियरग्राफबीडीबी, ग्राफबेस, इनफिनिटग्राफ और एलेग्रोग्राफ हैं।
ग्राफ़ डेटाबेस क्यों?
आजकल, अधिकांश डेटा विभिन्न वस्तुओं के बीच संबंध के रूप में मौजूद हैं और अधिक बार, डेटा के बीच संबंध डेटा की तुलना में अधिक मूल्यवान है।
संबंधपरक डेटाबेस अत्यधिक संरचित डेटा को संग्रहीत करते हैं जिनके पास एक ही प्रकार के डेटा को संग्रहीत करने वाले कई रिकॉर्ड होते हैं ताकि उनका उपयोग संरचित डेटा को संग्रहीत करने के लिए किया जा सके और, वे डेटा के बीच संबंधों को संग्रहीत नहीं करते हैं।
अन्य डेटाबेस के विपरीत, ग्राफ़ डेटाबेस प्रथम श्रेणी संस्थाओं के रूप में संबंधों और कनेक्शनों को संग्रहीत करता है।
ग्राफ डेटाबेस के लिए डेटा मॉडल अन्य डेटाबेस की तुलना में सरल है और, उन्हें ओएलटीपी सिस्टम के साथ उपयोग किया जा सकता है। वे लेनदेन अखंडता और परिचालन उपलब्धता जैसी सुविधाएँ प्रदान करते हैं।
RDBMS बनाम ग्राफ़ डेटाबेस
निम्नलिखित तालिका है जो रिलेशनल डेटाबेस और ग्राफ़ डेटाबेस की तुलना करती है।
अनु क्रमांक | आरडीबीएमएस | ग्राफ़ डेटाबेस |
---|---|---|
1 | टेबल | रेखांकन |
2 | पंक्तियों | नोड्स |
3 | कॉलम और डेटा | गुण और उसके मूल्य |
4 | प्रतिबन्ध | रिश्तों |
5 | में शामिल | traversal |
Neo4j के लाभ
Neo4j के फायदे निम्नलिखित हैं।
Flexible data model - Neo4j एक लचीला सरल और अभी तक शक्तिशाली डेटा मॉडल प्रदान करता है, जिसे अनुप्रयोगों और उद्योगों के अनुसार आसानी से बदला जा सकता है।
Real-time insights - Neo4j वास्तविक समय के आंकड़ों के आधार पर परिणाम प्रदान करता है।
High availability - Neo4j बड़े उद्यम वास्तविक समय के लिए उपलब्ध है जो लेनदेन की गारंटी के साथ उपलब्ध है।
Connected and semi structures data - Neo4j का उपयोग करके, आप आसानी से कनेक्टेड और सेमी-स्ट्रक्चर्ड डेटा का प्रतिनिधित्व कर सकते हैं।
Easy retrieval - Neo4j का उपयोग करते हुए, आप अन्य डेटाबेस की तुलना में न केवल प्रतिनिधित्व कर सकते हैं, बल्कि आसानी से जुड़े डेटा (ट्रैवर्स / नेविगेट) को तेजी से प्राप्त कर सकते हैं।
Cypher query language- Neo4j आस्की-आर्ट सिंटैक्स का उपयोग करते हुए, ग्राफ को नेत्रहीन रूप से दर्शाने के लिए एक घोषणात्मक क्वेरी भाषा प्रदान करता है। इस भाषा के आदेश मानव पठनीय प्रारूप में हैं और सीखने में बहुत आसान हैं।
No joins Neo4j का उपयोग करते हुए, कनेक्टेड / संबंधित डेटा को पुनः प्राप्त करने के लिए जटिल जॉइन की आवश्यकता नहीं होती है क्योंकि जॉइन या इंडेक्स के बिना इसके आसन्न नोड या रिलेशनशिप विवरण को पुनः प्राप्त करना बहुत आसान है।
Neo4j की विशेषताएं
Neo4j की उल्लेखनीय विशेषताएं निम्नलिखित हैं -
Data model (flexible schema)- Neo4j एक प्रॉपर्टी मॉडल का अनुसरण करता है जिसका नाम नेटिव प्रॉपर्टी ग्राफ मॉडल है। यहाँ, ग्राफ़ में नोड्स (निकाय) हैं और ये नोड्स एक दूसरे से जुड़े हुए हैं (रिश्तों द्वारा दर्शाए गए हैं)। गुण के रूप में ज्ञात कुंजी-मूल्य जोड़े में नोड्स और रिश्ते डेटा संग्रहीत करते हैं।
Neo4j में, एक निश्चित स्कीमा का पालन करने की आवश्यकता नहीं है। आप आवश्यकता के अनुसार गुण जोड़ या हटा सकते हैं। यह स्कीमा बाधाओं को भी प्रदान करता है।
ACID properties - Neo4j पूर्ण ACID (एटोमिसिटी, कंसिस्टेंसी, आइसोलेशन, और ड्यूरेबिलिटी) नियमों का समर्थन करता है।
Scalability and reliability- आप क्वेरी प्रसंस्करण गति और डेटा अखंडता को प्रभावित किए बिना रीड / राइट की संख्या और वॉल्यूम बढ़ाकर डेटाबेस को स्केल कर सकते हैं। Neo4j भी समर्थन प्रदान करता हैreplication डेटा सुरक्षा और विश्वसनीयता के लिए।
Cypher Query Language- Neo4j एक शक्तिशाली घोषणात्मक क्वेरी भाषा प्रदान करता है जिसे साइरफ के नाम से जाना जाता है। यह रेखांकन को दर्शाने के लिए ASCII- कला का उपयोग करता है। साइफ़र सीखना आसान है और इसका उपयोग जॉइन जैसे जटिल प्रश्नों के उपयोग के बिना डेटा के बीच संबंध बनाने और पुनः प्राप्त करने के लिए किया जा सकता है।
Built-in web application - Neo4j बिल्ट-इन प्रदान करता है Neo4j Browserवेब एप्लीकेशन। इसका उपयोग करके, आप अपना ग्राफ डेटा बना और क्वेरी कर सकते हैं।
Drivers - Neo4j के साथ काम कर सकते हैं -
REST API प्रोग्रामिंग लैंग्वेज जैसे जावा, स्प्रिंग, स्काला आदि के साथ काम करने के लिए।
जावा स्क्रिप्ट Node JS जैसे UI MVC फ्रेमवर्क के साथ काम करने के लिए।
जावा अनुप्रयोगों को विकसित करने के लिए यह दो प्रकार के जावा एपीआई का समर्थन करता है: साइपर एपीआई और नेटिव जावा एपीआई। इनके अतिरिक्त, आप अन्य डेटाबेस जैसे MongoDB, Cassandra, आदि के साथ भी काम कर सकते हैं।
Indexing - Neo4j Apache Lucence का उपयोग करके अनुक्रमित का समर्थन करता है।
Neo4j संपत्ति ग्राफ डेटा मॉडल
Neo4j ग्राफ़ डेटाबेस अपने डेटा को संग्रहीत और प्रबंधित करने के लिए संपत्ति ग्राफ़ मॉडल का अनुसरण करता है।
प्रॉपर्टी ग्राफ मॉडल की प्रमुख विशेषताएं निम्नलिखित हैं -
मॉडल नोड्स, रिश्ते और गुणों में डेटा का प्रतिनिधित्व करता है
गुण कुंजी-मूल्य जोड़े हैं
नोड्स को सर्कल का उपयोग करके दर्शाया गया है और रिश्तों को तीर कुंजी का उपयोग करके दर्शाया गया है
रिश्तों की दिशाएँ हैं: अप्रत्यक्ष और अप्रत्यक्ष
प्रत्येक रिश्ते में "स्टार्ट नोड" या "नोड से" और "टू नोड" या "एंड नोड" शामिल हैं।
नोड्स और रिलेशनशिप दोनों में गुण होते हैं
रिश्ते नोड्स को जोड़ता है
प्रॉपर्टी ग्राफ डेटा मॉडल में, रिश्ते दिशात्मक होने चाहिए। यदि हम दिशा के बिना संबंध बनाने की कोशिश करते हैं, तो यह एक त्रुटि संदेश फेंक देगा।
Neo4j में भी, रिश्ते दिशात्मक होने चाहिए। यदि हम दिशा के बिना संबंध बनाने की कोशिश करते हैं, तो Neo4j यह कहते हुए एक त्रुटि संदेश फेंक देगा कि "रिश्तों को दिशात्मक होना चाहिए"।
Neo4j ग्राफ़ डेटाबेस अपने सभी डेटा को नोड्स और रिलेशनशिप में संग्रहीत करता है। Neo4j डेटाबेस डेटा को स्टोर करने के लिए हमें न तो किसी अतिरिक्त आरआरबीएमएस डेटाबेस और न ही किसी SQL डेटाबेस की आवश्यकता है। यह अपने डेटा को अपने मूल प्रारूप में ग्राफ़ के संदर्भ में संग्रहीत करता है।
Neo4j अपने नेटिव ग्राफ़ स्टोरेज प्रारूप के साथ काम करने के लिए नेटिव GPE (ग्राफ़ प्रोसेसिंग इंजन) का उपयोग करता है।
ग्राफ डीबी डेटा मॉडल के मुख्य बिल्डिंग ब्लॉक हैं -
- Nodes
- Relationships
- Properties
निम्नलिखित एक संपत्ति ग्राफ का एक सरल उदाहरण है।
यहां, हमने मंडलियों का उपयोग करते हुए नोड्स का प्रतिनिधित्व किया है। एरो का उपयोग करके रिश्तों का प्रतिनिधित्व किया जाता है। रिश्ते दिशात्मक हैं। हम गुण (कुंजी-मूल्य जोड़े) के संदर्भ में नोड के डेटा का प्रतिनिधित्व कर सकते हैं। इस उदाहरण में, हमने नोड के सर्कल के भीतर प्रत्येक नोड की आईडी संपत्ति का प्रतिनिधित्व किया है।
इस अध्याय में, हम एक्सई फ़ाइल का उपयोग करके अपने सिस्टम में Neo4j को स्थापित करने के तरीके के बारे में चर्चा करेंगे।
Neo4j डेटाबेस सर्वर सेटअप Windows exe फाइल के साथ
Neo4j को अपने सिस्टम में डाउनलोड करने के लिए नीचे दिए गए चरणों का पालन करें।
Step 1 का उपयोग करते हुए Neo4j आधिकारिक साइट पर जाएं https://neo4j.com/। क्लिक करने पर, यह लिंक आपको neo4j वेबसाइट के होमपेज पर ले जाएगा।
Step 2- जैसा कि ऊपर दिए गए स्क्रीनशॉट में हाइलाइट किया गया है, इस पेज में टॉप राइट हैंड साइड में डाउनलोड बटन है। इसे क्लिक करें।
Step 3- यह आपको डाउनलोड पृष्ठ पर पुनर्निर्देशित करेगा, जहां आप समुदाय संस्करण और Neo4j के उद्यम संस्करण को डाउनलोड कर सकते हैं। संबंधित बटन पर क्लिक करके सॉफ्टवेयर का सामुदायिक संस्करण डाउनलोड करें।
Step 4- यह आपको उस पृष्ठ पर ले जाएगा जहां आप Neo4j सॉफ़्टवेयर के सामुदायिक संस्करण को विभिन्न ऑपरेटिंग सिस्टम के साथ संगत डाउनलोड कर सकते हैं। वांछित ऑपरेटिंग सिस्टम से संबंधित फ़ाइल डाउनलोड करें।
यह नामक एक फाइल डाउनलोड करेगा neo4j-community_windows-x64_3_1_1.exe अपने सिस्टम को निम्न स्क्रीनशॉट में दिखाया गया है।
Step 5 - Neo4j सर्वर को स्थापित करने के लिए exe फ़ाइल को डबल-क्लिक करें।
Step 6- लाइसेंस समझौते को स्वीकार करें और स्थापना के साथ आगे बढ़ें। प्रक्रिया पूरी होने के बाद, आप देख सकते हैं कि Neo4j आपके सिस्टम में स्थापित है।
सर्वर शुरू करना
Step 1 - Windows startmenu पर क्लिक करें और Neo4j के लिए स्टार्ट मेनू शॉर्टकट पर क्लिक करके Neo4j सर्वर शुरू करें।
Step 2- शॉर्टकट पर क्लिक करने पर, आपको Neo4j कम्युनिटी एडिशन के लिए एक विंडो मिलेगी। डिफ़ॉल्ट रूप से, यह c: \ Users \ [username] \ Documents \ Neo4j \ default.graphdb का चयन करता है। यदि आप चाहें, तो आप अपना रास्ता अलग निर्देशिका में बदल सकते हैं।
Step 3 - Neo4j सर्वर शुरू करने के लिए "प्रारंभ" बटन पर क्लिक करें।
एक बार सर्वर शुरू होने के बाद, आप यह देख सकते हैं कि डेटाबेस निर्देशिका पॉपुलेटेड है जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।
Neo4j के साथ काम करना
जैसा कि पिछले अध्यायों में चर्चा की गई है, neo4j Neo4j के साथ काम करने के लिए एक अंतर्निहित ब्राउज़ एप्लिकेशन प्रदान करता है। आप URL का उपयोग करके Neo4j तक पहुँच सकते हैंhttp://localhost:7474/
Neo4j ग्राफ़ डेटाबेस में निम्नलिखित बिल्डिंग ब्लॉक्स हैं -
- Nodes
- Properties
- Relationships
- Labels
- डेटा ब्राउज़र
नोड
नोड एक ग्राफ की एक मूलभूत इकाई है। इसमें कुंजी-मूल्य जोड़े के साथ गुण हैं जैसा कि निम्नलिखित छवि में दिखाया गया है।
यहां, नोड नाम = "कर्मचारी" और इसमें कुंजी-मूल्य जोड़े के रूप में गुणों का एक सेट शामिल है।
गुण
संपत्ति ग्राफ-नोड्स और संबंधों का वर्णन करने के लिए एक महत्वपूर्ण-मूल्य जोड़ी है।
Key = Value
जहां Key एक स्ट्रिंग है और किसी भी Neo4j डेटा प्रकार का उपयोग करके मूल्य का प्रतिनिधित्व किया जा सकता है।
रिश्तों
रिलेशनशिप एक ग्राफ डेटाबेस का एक और प्रमुख बिल्डिंग ब्लॉक है। यह निम्न आकृति में दर्शाए अनुसार दो नोड्स को जोड़ता है।
यहां, Emp और Dept दो अलग-अलग नोड्स हैं। "WORKS_FOR" Emp और Dept nodes के बीच का संबंध है।
जैसा कि यह दर्शाता है, Emp से Dept के लिए तीर का निशान, यह संबंध बताता है -
Emp WORKS_FOR Dept
प्रत्येक रिश्ते में एक स्टार्ट नोड और एक एंड नोड होता है।
यहाँ, "एम्प" एक स्टार्ट नोड है, और "डिप" एक एंड नोड है।
जैसा कि यह संबंध तीर चिह्न "Emp" नोड से "Dept" नोड के बीच के संबंध को दर्शाता है, इस संबंध को "Inpt" रिश्ते को "Dept" नोड और "आउटगोइंग रिलेशनशिप" को "Emp" नोड के रूप में जाना जाता है।
नोड्स की तरह, रिश्तों में भी कुंजी-मूल्य जोड़े के रूप में गुण हो सकते हैं।
यहां, "WORKS_FOR" रिश्ते में कुंजी-मूल्य जोड़ी के रूप में एक संपत्ति है।
Id = 123
यह इस रिश्ते की एक आईडी का प्रतिनिधित्व करता है।
लेबल
लेबल एक सामान्य नाम को नोड्स या संबंधों के समूह में जोड़ता है। एक नोड या संबंध में एक या अधिक लेबल हो सकते हैं। हम मौजूदा नोड्स या संबंधों के लिए नए लेबल बना सकते हैं। हम मौजूदा लेबल को मौजूदा नोड्स या रिश्तों से हटा सकते हैं।
पिछले आरेख से, हम देख सकते हैं कि दो नोड हैं।
लेफ्ट साइड नोड में एक लेबल होता है: "एम्प" और राइट साइड नोड में एक लेबल होता है: "विभाग"।
उन दो नोड्स के बीच संबंध में एक लेबल भी है: "WORKS_FOR"।
Note - Neo4j प्रॉपर्टीज ऑफ नोड्स या रिलेशनशिप में डेटा स्टोर करता है।
Neo4j डेटा ब्राउज़र
एक बार जब हम Neo4j स्थापित करते हैं, तो हम निम्न URL का उपयोग करके Neo4j डेटा ब्राउज़र तक पहुँच सकते हैं
http://localhost:7474/browser/
Neo4j Data Browser का उपयोग CQL कमांड को निष्पादित करने और आउटपुट को देखने के लिए किया जाता है।
यहां, हमें डॉलर प्रॉम्प्ट पर सभी CQL कमांड निष्पादित करने की आवश्यकता है: "$"
डॉलर के प्रतीक के बाद कमांड टाइप करें और अपने कमांड को चलाने के लिए "एक्सक्यूट" बटन पर क्लिक करें।
यह Neo4j डेटाबेस सर्वर के साथ इंटरैक्ट करता है, डॉलर प्रॉम्प्ट के ठीक नीचे परिणामों को पुनर्प्राप्त और प्रदर्शित करता है।
आरेख प्रारूप में परिणाम देखने के लिए "VI दृश्य" बटन का उपयोग करें। उपरोक्त आरेख "UI दृश्य" प्रारूप में परिणाम दिखाता है।
ग्रिड दृश्य में परिणाम देखने के लिए "ग्रिड दृश्य" बटन का उपयोग करें। निम्नलिखित आरेख "ग्रिड व्यू" प्रारूप में समान परिणाम दिखाता है।
जब हम अपने क्वेरी परिणामों को देखने के लिए "ग्रिड व्यू" का उपयोग करते हैं, तो हम उन्हें दो अलग-अलग स्वरूपों में एक फ़ाइल में निर्यात कर सकते हैं।
सीएसवी
सीएसवी फ़ाइल प्रारूप में परिणाम निर्यात करने के लिए "निर्यात सीएसवी" बटन पर क्लिक करें।
JSON
JSON फ़ाइल स्वरूप में परिणाम निर्यात करने के लिए "निर्यात JSON" बटन पर क्लिक करें।
हालाँकि, यदि हम अपने क्वेरी परिणामों को देखने के लिए "UI व्यू" का उपयोग करते हैं, तो हम उन्हें केवल एक प्रारूप में एक फ़ाइल में निर्यात कर सकते हैं: JSON
CQL का मतलब सिगरफ क्वेरी लैंग्वेज है। जैसे Oracle डेटाबेस में क्वेरी भाषा SQL है, वैसे ही Neo4j में CQL क्वेरी भाषा है।
Neo4j CQL
- Neo4j Graph डेटाबेस के लिए एक क्वेरी भाषा है।
- एक घोषणात्मक पैटर्न-मिलान भाषा है।
- सिंटैक्स की तरह SQL का अनुसरण करता है।
- सिंटेक्स बहुत सरल और मानव पठनीय प्रारूप में है।
ओरेकल एसक्यूएल की तरह
Neo4j CQL के पास डेटाबेस ऑपरेशन करने के लिए कमांड हैं।
Neo4j CQL कई क्लॉज़ जैसे WHERE, ORDER BY आदि का समर्थन करता है, बहुत जटिल प्रश्नों को आसान तरीके से लिखने के लिए।
Neo4j CQL कुछ कार्यों का समर्थन करता है जैसे स्ट्रिंग, एकत्रीकरण। उनके अलावा, यह कुछ रिलेशनशिप फंक्शंस को भी सपोर्ट करता है।
Neo4j CQL क्लाज
Neo4j के रीड क्लॉज निम्नलिखित हैं Cypher Query Lपीड़ा -
अनु क्रमांक | क्लाज पढ़ें | प्रयोग |
---|---|---|
1 | मैच | यह क्लॉज एक निर्दिष्ट पैटर्न के साथ डेटा को खोजने के लिए उपयोग किया जाता है। |
2 | वैकल्पिक सामग्री | यह मैच के समान है, एकमात्र अंतर यह है कि यह पैटर्न के लापता भागों के मामले में नल का उपयोग कर सकता है। |
3 | कहाँ पे | इस खंड आईडी का उपयोग CQL प्रश्नों के लिए सामग्री जोड़ने के लिए किया जाता है। |
4 | शुरू | इस खंड का उपयोग विरासत सूचकांक के माध्यम से शुरुआती बिंदुओं को खोजने के लिए किया जाता है। |
5 | लोड सीएसवी | इस खंड का उपयोग CSV फ़ाइलों से डेटा आयात करने के लिए किया जाता है। |
निम्नलिखित Neo4j के लेखन खंड हैं Cypher Query Lपीड़ा -
अनु क्रमांक | क्लॉज लिखें | प्रयोग |
---|---|---|
1 | सृजन करना | इस क्लॉज का उपयोग नोड्स, रिश्ते और गुण बनाने के लिए किया जाता है। |
2 | मर्ज | यह क्लॉज़ सत्यापित करता है कि ग्राफ़ में निर्दिष्ट पैटर्न मौजूद है या नहीं। यदि नहीं, तो यह पैटर्न बनाता है। |
3 | सेट | इस क्लॉज का उपयोग नोड्स पर लेबल, नोड्स और संबंधों पर गुणों को अपडेट करने के लिए किया जाता है। |
4 | हटाएँ | इस क्लॉज का उपयोग ग्राफ से नोड्स और रिश्तों या रास्तों आदि को हटाने के लिए किया जाता है। |
5 | हटाना | इस क्लॉज का उपयोग नोड्स और रिश्तों से गुणों और तत्वों को हटाने के लिए किया जाता है। |
6 | प्रत्येक के लिए | इस वर्ग का उपयोग किसी सूची में डेटा को अपडेट करने के लिए किया जाता है। |
7 | अद्वितीय बनाने | क्लॉज क्रिएट और MATCH का उपयोग करके, आप मौजूदा पैटर्न से मेल करके और लापता को बनाकर एक अद्वितीय पैटर्न प्राप्त कर सकते हैं। |
8 | CyV के साथ CSV फ़ाइलों को आयात करना | लोड CSV का उपयोग करके आप .csv फ़ाइलों से डेटा आयात कर सकते हैं। |
Neo4j के सामान्य खंड निम्नलिखित हैं Cypher Query Lपीड़ा -
अनु क्रमांक | सामान्य खंड | प्रयोग |
---|---|---|
1 | वापसी | इस क्लॉज का उपयोग यह निर्धारित करने के लिए किया जाता है कि क्वेरी परिणाम सेट में क्या शामिल किया जाए। |
2 | द्वारा आदेश | इस खंड का उपयोग क्रम में एक क्वेरी के आउटपुट को व्यवस्थित करने के लिए किया जाता है। इसका उपयोग खण्डों के साथ किया जाता हैRETURN या WITH। |
3 | आप LIMIT | इस खंड का उपयोग विशिष्ट मान में परिणाम में पंक्तियों को सीमित करने के लिए किया जाता है। |
4 | छोड़ें | इस क्लॉज का उपयोग आउटपुट में पंक्तियों सहित किस पंक्ति को शुरू करने के लिए परिभाषित करने के लिए किया जाता है। |
5 | साथ में | इस खंड का उपयोग क्वेरी भागों को एक साथ चेन करने के लिए किया जाता है। |
6 | खोलना | इस खंड का उपयोग पंक्तियों के अनुक्रम में एक सूची का विस्तार करने के लिए किया जाता है। |
7 | संघ | इस क्लॉज का उपयोग कई प्रश्नों के परिणाम को संयोजित करने के लिए किया जाता है। |
8 | कॉल | इस खंड का उपयोग डेटाबेस में तैनात एक प्रक्रिया को लागू करने के लिए किया जाता है। |
Neo4j CQL कार्य
निम्नलिखित अक्सर इस्तेमाल किए जाने वाले Neo4j CQL कार्य हैं -
अनु क्रमांक | CQL कार्य | प्रयोग |
---|---|---|
1 | तार | वे स्ट्रिंग शाब्दिक के साथ काम करने के लिए उपयोग किए जाते हैं। |
2 | एकत्रीकरण | CQL क्वेरी परिणामों पर कुछ एकत्रीकरण संचालन करने के लिए उनका उपयोग किया जाता है। |
3 | संबंध | उनका उपयोग रिश्तों का विवरण प्राप्त करने के लिए किया जाता है जैसे कि स्टार्टअप, एंडनोड, आदि। |
हम सभी Neo4j CQL कमांड्स, क्लॉज़ और फ़ंक्शंस सिंटैक्स, उपयोग और उदाहरणों के बारे में बाद के अध्यायों में विस्तार से चर्चा करेंगे।
Neo4j CQL डेटा प्रकार
ये डेटा प्रकार जावा भाषा के समान हैं। उनका उपयोग नोड या रिश्ते के गुणों को परिभाषित करने के लिए किया जाता है।
Neo4j CQL निम्नलिखित डेटा प्रकारों का समर्थन करता है -
अनु क्रमांक | CQL डेटा प्रकार | प्रयोग |
---|---|---|
1 | बूलियन | इसका उपयोग बूलियन शाब्दिक प्रतिनिधित्व करने के लिए किया जाता है: सच, गलत। |
2 | बाइट | इसका उपयोग 8-बिट पूर्णांक का प्रतिनिधित्व करने के लिए किया जाता है। |
3 | कम | इसका उपयोग 16-बिट पूर्णांक का प्रतिनिधित्व करने के लिए किया जाता है। |
4 | पूर्णांक | इसका उपयोग 32-बिट पूर्णांक का प्रतिनिधित्व करने के लिए किया जाता है। |
5 | लंबा | इसका उपयोग 64-बिट पूर्णांक का प्रतिनिधित्व करने के लिए किया जाता है। |
6 | नाव | इसका उपयोग 32-बिट फ्लोटिंग-पॉइंट संख्याओं का प्रतिनिधित्व करने के लिए किया जाता है। |
7 | दोहरा | इसका उपयोग 64-बिट फ्लोटिंग-पॉइंट संख्याओं का प्रतिनिधित्व करने के लिए किया जाता है। |
8 | चार | इसका उपयोग 16-बिट वर्णों का प्रतिनिधित्व करने के लिए किया जाता है। |
9 | तार | इसका उपयोग स्ट्रिंग्स का प्रतिनिधित्व करने के लिए किया जाता है। |
CQL ऑपरेटरों
Neo4j Cypher क्वेरी भाषा द्वारा समर्थित ऑपरेटरों की सूची निम्नलिखित है।
अनु क्रमांक | प्रकार | ऑपरेटर्स |
---|---|---|
1 | गणितीय | +, -, *, /,%, ^ |
2 | तुलना | +, <>, <,>, <=,> = |
3 | बूलियन | और, या, XOR, नहीं |
4 | तार | + |
5 | सूची | +, IN, [X], [X… ..Y] |
6 | नियमित अभिव्यक्ति | = - |
7 | स्ट्रिंग मिलान | स्टार्स विथ, ईएनडीएस विद कन्स्ट्रक्ट्स |
Neo4j CQL में बूलियन ऑपरेटर्स
Neo4j कई स्थितियों का समर्थन करने के लिए Neo4j CQL में क्लॉज का उपयोग करने के लिए निम्नलिखित बूलियन ऑपरेटरों का समर्थन करता है।
अनु क्रमांक | बूलियन ऑपरेटर्स | विवरण |
---|---|---|
1 | तथा | यह समर्थन और संचालन के लिए एक Neo4j CQL कीवर्ड है। यह SQL AND ऑपरेटर की तरह है। |
2 | या | यह OR4 ऑपरेशन का समर्थन करने के लिए एक Neo4j CQL कीवर्ड है। यह SQL AND ऑपरेटर की तरह है। |
3 | नहीं | यह एक Neo4j CQL कीवर्ड है जो ऑपरेशन का समर्थन नहीं करता है। यह SQL AND ऑपरेटर की तरह है। |
4 | XOR | यह XOR ऑपरेशन का समर्थन करने के लिए एक Neo4j CQL कीवर्ड है। यह SQL AND ऑपरेटर की तरह है। |
Neo4j CQL में तुलना ऑपरेटर
Neo4j शर्तों का समर्थन करने के लिए Neo4j CQL में उपयोग करने के लिए निम्नलिखित तुलना ऑपरेटरों का समर्थन करता है।
अनु क्रमांक | बूलियन ऑपरेटर्स | विवरण |
---|---|---|
1 | = | यह एक Neo4j CQL "ऑपरेटर के बराबर" है। |
2 | <> | यह एक Neo4j CQL "ऑपरेटर के बराबर नहीं" ऑपरेटर है। |
3 | < | यह एक Neo4j CQL "कम से कम" ऑपरेटर है। |
4 | > | यह एक Neo4j CQL "ग्रेटर थान" ऑपरेटर है। |
5 | <= | यह एक Neo4j CQL "ऑपरेटर से कम या बराबर" है। |
6 | > = | यह एक Neo4j CQL "ग्रेटर थान या इक्वल टू" ऑपरेटर है। |
जैसा कि चर्चा की गई है, एक नोड एक ग्राफ डेटाबेस में एक डेटा / रिकॉर्ड है। आप Neo4j का उपयोग करके एक नोड बना सकते हैंCREATEखंड। यह अध्याय आपको सिखाता है कि कैसे -
- एक नोड बनाएँ
- कई नोड बनाएं
- एक लेबल के साथ एक नोड बनाएँ
- कई लेबल के साथ एक नोड बनाएँ
- गुणों के साथ एक नोड बनाएँ
- बनाए गए नोड को वापस करना
एक एकल नोड बनाना
आप केवल बनावटी खंड के साथ बनाए जाने वाले नोड के नाम को निर्दिष्ट करके Neo4j में एक नोड बना सकते हैं।
वाक्य - विन्यास
साइफर क्वेरी लैंग्वेज का उपयोग करके नोड बनाने के लिए सिंटैक्स निम्नलिखित है।
CREATE (node_name);
Note - अर्धविराम (;) वैकल्पिक है।
उदाहरण
निम्नलिखित एक नमूना Cypher क्वेरी है जो Neo4j में एक नोड बनाता है।
CREATE (sample)
उपरोक्त क्वेरी निष्पादित करने के लिए, निम्न चरणों का पालन करें -
Step 1 - Neo4j डेस्कटॉप ऐप खोलें और निम्न स्क्रीनशॉट में दिखाए अनुसार Neo4j सर्वर शुरू करें।
Step 2 - अपना ब्राउज़र खोलें, अपने एड्रेस बार में निम्न URL को कॉपी करें http://localhost:7474/. यह आपको निंरग स्क्रीनशॉट के साथ एक निनजा डॉलर के साथ Neo4j का बिल्ट-इन ब्राउजर ऐप देगा।
Step 3 - डॉलर प्रॉम्प्ट में वांछित क्वेरी को कॉपी और पेस्ट करें और निम्न स्क्रीनशॉट में हाइलाइट किए गए प्ले बटन (क्वेरी को निष्पादित करने के लिए) दबाएं।
परिणाम
निष्पादित करने पर, आपको निम्नलिखित परिणाम मिलेगा।
सत्यापन
नोड प्रकार के निर्माण को सत्यापित करने के लिए, डॉलर प्रॉम्प्ट में निम्नलिखित क्वेरी को निष्पादित करें।
MATCH (n) RETURN n
यह क्वेरी डेटाबेस में सभी नोड्स देता है (हम आने वाले अध्यायों में इस क्वेरी के बारे में विस्तार से चर्चा करेंगे)।
निष्पादित करने पर, यह क्वेरी बनाई गई नोड को दिखाती है जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।
कई नोड्स बनाना
Neo4j CQL का बना हुआ क्लॉज भी एक ही समय में कई नोड्स बनाने के लिए उपयोग किया जाता है। ऐसा करने के लिए, आपको एक अल्पविराम द्वारा अलग किए जाने वाले नोड्स के नामों को पारित करने की आवश्यकता है।
वाक्य - विन्यास
क्रिएट क्लॉज का उपयोग करके कई नोड्स बनाने के लिए सिंटैक्स निम्नलिखित है।
CREATE (node1),(node2)
उदाहरण
निम्नलिखित एक नमूना Cypher क्वेरी है जो Neo4j में कई नोड बनाता है।
CREATE (sample1),(sample2)
उपरोक्त क्वेरी निष्पादित करने के लिए, निम्न चरणों का पालन करें -
Step 1- Neo4j डेस्कटॉप ऐप खोलें और Neo4j सर्वर शुरू करें। URL का उपयोग करके Neo4j का अंतर्निहित ब्राउज़र ऐप खोलेंhttp://localhost:7474/ जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।
Step 2 - डॉलर प्रॉम्प्ट में वांछित क्वेरी को कॉपी और पेस्ट करें और निम्न स्क्रीनशॉट में हाइलाइट किए गए प्ले बटन (क्वेरी को निष्पादित करने के लिए) दबाएं।
परिणाम
निष्पादित करने पर, आपको निम्नलिखित परिणाम मिलेगा।
सत्यापन
नोड के निर्माण को सत्यापित करने के लिए, डॉलर प्रांप्ट में निम्नलिखित क्वेरी टाइप करें और निष्पादित करें।
MATCH (n) RETURN n
यह क्वेरी डेटाबेस में सभी नोड्स देता है (हम आने वाले अध्यायों में इस क्वेरी के बारे में विस्तार से चर्चा करेंगे)।
निष्पादित करने पर, यह क्वेरी बनाई गई नोड को दिखाती है जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।
एक लेबल के साथ एक नोड बनाना
Neo4j में एक लेबल का उपयोग नोड्स को समूह (वर्गीकृत) करने के लिए किया जाता है। आप CREATE क्लॉज का उपयोग करके Neo4j में नोड के लिए एक लेबल बना सकते हैं।
वाक्य - विन्यास
साइफर क्वेरी लैंग्वेज का उपयोग करके एक लेबल के साथ नोड बनाने के लिए सिंटैक्स निम्नलिखित है।
CREATE (node:label)
उदाहरण
निम्नलिखित एक नमूना साइपर क्वेरी है जो एक लेबल के साथ एक नोड बनाता है।
CREATE (Dhawan:player)
उपरोक्त क्वेरी निष्पादित करने के लिए, निम्न चरणों का पालन करें -
Step 1- Neo4j डेस्कटॉप ऐप खोलें और Neo4j सर्वर शुरू करें। URL का उपयोग करके Neo4j का अंतर्निहित ब्राउज़र ऐप खोलेंhttp://localhost:7474/ जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।
Step 2 - डॉलर प्रॉम्प्ट में वांछित क्वेरी को कॉपी और पेस्ट करें और निम्न स्क्रीनशॉट में हाइलाइट किए गए प्ले बटन (क्वेरी को निष्पादित करने के लिए) दबाएं।
परिणाम
निष्पादित करने पर, आपको निम्नलिखित परिणाम मिलेगा।
सत्यापन
नोड के निर्माण को सत्यापित करने के लिए, डॉलर प्रांप्ट में निम्नलिखित क्वेरी टाइप करें और निष्पादित करें।
MATCH (n) RETURN n
यह क्वेरी डेटाबेस में सभी नोड्स देता है (हम आने वाले अध्यायों में इस क्वेरी के बारे में विस्तार से चर्चा करेंगे)।
निष्पादित करने पर, यह क्वेरी बनाई गई नोड को दिखाती है जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।
एकाधिक लेबल के साथ एक नोड बनाना
आप एकल नोड के लिए कई लेबल भी बना सकते हैं। आपको उन्हें एक "": से अलग करके नोड के लिए लेबल निर्दिष्ट करने की आवश्यकता है।
वाक्य - विन्यास
निम्नलिखित कई लेबल के साथ एक नोड बनाने के लिए वाक्यविन्यास है।
CREATE (node:label1:label2:. . . . labeln)
उदाहरण
निम्नलिखित एक नमूना Cypher क्वेरी है जो Neo4j में कई लेबल के साथ एक नोड बनाता है।
CREATE (Dhawan:person:player)
उपरोक्त क्वेरी निष्पादित करने के लिए, निम्न चरणों का पालन करें -
Step 1- Neo4j डेस्कटॉप ऐप खोलें और Neo4j सर्वर शुरू करें। URL का उपयोग करके Neo4j का अंतर्निहित ब्राउज़र ऐप खोलेंhttp://localhost:7474/ जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।
Step 2 - डॉलर प्रॉम्प्ट में वांछित क्वेरी को कॉपी और पेस्ट करें और निम्न स्क्रीनशॉट में हाइलाइट किए गए प्ले बटन (क्वेरी को निष्पादित करने के लिए) दबाएं।
परिणाम
निष्पादित करने पर, आपको निम्नलिखित परिणाम मिलेगा।
सत्यापन
नोड के निर्माण को सत्यापित करने के लिए, डॉलर प्रांप्ट में निम्नलिखित क्वेरी टाइप करें और निष्पादित करें।
MATCH (n) RETURN n
यह क्वेरी डेटाबेस में सभी नोड्स देता है (हम आने वाले अध्यायों में इस क्वेरी के बारे में विस्तार से चर्चा करेंगे)।
निष्पादित करने पर, यह क्वेरी बनाई गई नोड को दिखाती है जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।
गुणों के साथ नोड बनाएँ
गुण कुंजी-मूल्य जोड़े हैं जिनका उपयोग करके नोड डेटा संग्रहीत करता है। आप क्रिएट क्लॉज का उपयोग करके गुणों के साथ एक नोड बना सकते हैं। आपको फूल ब्रेस "{}" के भीतर अल्पविराम से अलग इन गुणों को निर्दिष्ट करने की आवश्यकता है।
वाक्य - विन्यास
गुणों के साथ नोड बनाने के लिए सिंटैक्स निम्नलिखित है।
CREATE (node:label { key1: value, key2: value, . . . . . . . . . })
उदाहरण
निम्नलिखित एक नमूना साइफर क्वेरी है जो गुणों के साथ एक नोड बनाता है।
CREATE (Dhawan:player{name: "Shikar Dhawan", YOB: 1985, POB: "Delhi"})
उपरोक्त क्वेरी निष्पादित करने के लिए, निम्न चरणों का पालन करें -
Step 1- Neo4j डेस्कटॉप ऐप खोलें और Neo4j सर्वर शुरू करें। URL का उपयोग करके Neo4j का अंतर्निहित ब्राउज़र ऐप खोलेंhttp://localhost:7474/ जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।
Step 2 - डॉलर प्रॉम्प्ट में वांछित क्वेरी को कॉपी और पेस्ट करें और निम्न स्क्रीनशॉट में हाइलाइट किए गए प्ले बटन (क्वेरी को निष्पादित करने के लिए) दबाएं।
परिणाम
निष्पादित करने पर, आपको निम्नलिखित परिणाम मिलेगा।
सत्यापन
नोड के निर्माण को सत्यापित करने के लिए, डॉलर प्रांप्ट में निम्नलिखित क्वेरी टाइप करें और निष्पादित करें।
MATCH (n) RETURN n
यह क्वेरी डेटाबेस में सभी नोड्स देता है (हम आने वाले अध्यायों में इस क्वेरी के बारे में विस्तार से चर्चा करेंगे)।
निष्पादित करने पर, यह क्वेरी बनाई गई नोड को दिखाती है जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।
लौटकर बनाया गया नोड
पूरे अध्याय में, हमने इसका इस्तेमाल किया MATCH (n) RETURN nनिर्मित नोड्स देखने के लिए क्वेरी। यह क्वेरी डेटाबेस के सभी मौजूदा नोड्स को लौटाता है।
इसके बजाय, हम नए बनाए गए नोड को देखने के लिए CREATE के साथ RETURN क्लॉज का उपयोग कर सकते हैं।
वाक्य - विन्यास
Neo4j में एक नोड वापस करने के लिए सिंटैक्स है।
CREATE (Node:Label{properties. . . . }) RETURN Node
उदाहरण
निम्नलिखित एक नमूना साइफर क्वेरी है जो गुणों के साथ एक नोड बनाता है और इसे वापस करता है।
CREATE (Dhawan:player{name: "Shikar Dhawan", YOB: 1985, POB: "Delhi"}) RETURN Dhawan
उपरोक्त क्वेरी निष्पादित करने के लिए, निम्न चरणों का पालन करें -
Step 1- Neo4j डेस्कटॉप ऐप खोलें और Neo4j सर्वर शुरू करें। URL का उपयोग करके Neo4j का अंतर्निहित ब्राउज़र ऐप खोलेंhttp://localhost:7474/ जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।
Step 2 - डॉलर प्रॉम्प्ट में वांछित क्वेरी को कॉपी और पेस्ट करें और निम्न स्क्रीनशॉट में हाइलाइट किए गए प्ले बटन (क्वेरी को निष्पादित करने के लिए) दबाएं।
परिणाम
निष्पादित करने पर, आपको निम्नलिखित परिणाम मिलेगा।
Noe4j में, एक संबंध एक तत्व है जिसका उपयोग करके हम एक ग्राफ के दो नोड्स को जोड़ते हैं। इन रिश्तों में दिशा, प्रकार और डेटा के रूप पैटर्न हैं। यह अध्याय आपको सिखाता है कि कैसे -
- संबंध बनाएं
- मौजूदा नोड्स के बीच एक संबंध बनाएं
- लेबल और गुणों के साथ एक संबंध बनाएं
संबंध बनाना
हम क्रिएट क्लॉज का उपयोग करके संबंध बना सकते हैं। हम वर्ग ब्रेसेस के भीतर "[]" संबंध को निर्दिष्ट करेंगे, यह उस संबंध की दिशा पर निर्भर करता है जो इसे हाइफ़न "-" और तीर "→" के बीच रखा गया है जैसा कि निम्नलिखित सिंटैक्स में दिखाया गया है।
वाक्य - विन्यास
क्रिएट क्लॉज का उपयोग करके संबंध बनाने के लिए सिंटैक्स निम्नलिखित है।
CREATE (node1)-[:RelationshipType]->(node2)
उदाहरण
सबसे पहले, डेटाबेस में दो नोड्स इंडस्ट्रीज़ और धवन बनाएं, जैसा कि नीचे दिखाया गया है।
CREATE (Dhawan:player{name: "Shikar Dhawan", YOB: 1985, POB: "Delhi"})
CREATE (Ind:Country {name: "India"})
अब, नाम का एक संबंध बनाएं BATSMAN_OF इन दो नोड्स के बीच -
CREATE (Dhawan)-[r:BATSMAN_OF]->(Ind)
अंत में, बनाए गए रिश्ते को देखने के लिए दोनों नोड्स वापस करें।
RETURN Dhawan, Ind
डॉलर प्रॉम्प्ट में वांछित क्वेरी को कॉपी और पेस्ट करें और निम्न स्क्रीनशॉट में हाइलाइट किए गए प्ले बटन (क्वेरी को निष्पादित करने के लिए) दबाएं।
परिणाम
निष्पादित करने पर, आपको निम्नलिखित परिणाम मिलेगा।
मौजूदा नोड्स के बीच एक संबंध बनाना
आप मौजूदा नोड्स के बीच संबंध का उपयोग करके भी बना सकते हैं MATCH खंड।
वाक्य - विन्यास
MATCH क्लॉज का उपयोग करके संबंध बनाने के लिए सिंटैक्स निम्नलिखित है।
MATCH (a:LabeofNode1), (b:LabeofNode2)
WHERE a.name = "nameofnode1" AND b.name = " nameofnode2"
CREATE (a)-[: Relation]->(b)
RETURN a,b
उदाहरण
निम्नलिखित एक नमूना साइफर क्वेरी है जो मैच क्लॉज का उपयोग करके एक संबंध बनाता है।
MATCH (a:player), (b:Country) WHERE a.name = "Shikar Dhawan" AND b.name = "India"
CREATE (a)-[r: BATSMAN_OF]->(b)
RETURN a,b
उपरोक्त क्वेरी को निष्पादित करने के लिए, निम्न चरणों का पालन करें।
Step 1- Neo4j डेस्कटॉप ऐप खोलें और Neo4j सर्वर शुरू करें। URL का उपयोग करके Neo4j का अंतर्निहित ब्राउज़र ऐप खोलेंhttp://localhost:7474/ जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।
Step 2 - डॉलर प्रॉम्प्ट में वांछित क्वेरी को कॉपी और पेस्ट करें और निम्न स्क्रीनशॉट में हाइलाइट किए गए प्ले बटन (क्वेरी को निष्पादित करने के लिए) दबाएं।
परिणाम
निष्पादित करने पर, आपको निम्नलिखित परिणाम मिलेगा।
लेबल और गुणों के साथ एक संबंध बनाना
आप CREATE क्लॉज का उपयोग करके लेबल और गुणों के साथ संबंध बना सकते हैं।
वाक्य - विन्यास
निम्नलिखित रचना और लेबल के साथ संबंध बनाने के लिए वाक्य रचना का उपयोग कर रहा है।
CREATE (node1)-[label:Rel_Type {key1:value1, key2:value2, . . . n}]-> (node2)
उदाहरण
निम्नलिखित एक नमूना साइफर क्वेरी है जो लेबल और गुणों के साथ एक संबंध बनाता है।
MATCH (a:player), (b:Country) WHERE a.name = "Shikar Dhawan" AND b.name = "India"
CREATE (a)-[r:BATSMAN_OF {Matches:5, Avg:90.75}]->(b)
RETURN a,b
उपरोक्त क्वेरी निष्पादित करने के लिए, निम्न चरणों का पालन करें -
Step 1- Neo4j डेस्कटॉप ऐप खोलें और Neo4j सर्वर शुरू करें। URL का उपयोग करके Neo4j का अंतर्निहित ब्राउज़र ऐप खोलेंhttp://localhost:7474/ जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।
Step 2 - डॉलर प्रॉम्प्ट में वांछित क्वेरी को कॉपी और पेस्ट करें और निम्न स्क्रीनशॉट में हाइलाइट किए गए प्ले बटन (क्वेरी को निष्पादित करने के लिए) दबाएं।
परिणाम
निष्पादित करने पर, आपको निम्नलिखित परिणाम मिलेगा।
एक पूर्ण पथ बनाना
Neo4j में, निरंतर संबंधों का उपयोग करके एक पथ का निर्माण किया जाता है। बनाएँ क्लॉज़ का उपयोग करके एक पथ बनाया जा सकता है।
वाक्य - विन्यास
निओटेज क्लॉज का उपयोग करते हुए Neo4j में एक रास्ता बनाने के लिए सिंटैक्स निम्नलिखित है।
CREATE p = (Node1 {properties})-[:Relationship_Type]->
(Node2 {properties})[:Relationship_Type]->(Node3 {properties})
RETURN p
उदाहरण
उपरोक्त क्वेरी निष्पादित करने के लिए, निम्न चरणों का पालन करें -
Step 1- Neo4j डेस्कटॉप ऐप खोलें और Neo4j सर्वर शुरू करें। URL का उपयोग करके Neo4j का अंतर्निहित ब्राउज़र ऐप खोलेंhttp://localhost:7474/ जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।
Step 2 - डॉलर प्रॉम्प्ट में वांछित क्वेरी को कॉपी और पेस्ट करें और निम्न स्क्रीनशॉट में हाइलाइट किए गए प्ले बटन (क्वेरी को निष्पादित करने के लिए) दबाएं।
परिणाम
निष्पादित करने पर, आपको निम्नलिखित परिणाम मिलेगा।
MERGE कमांड CREATE कमांड और MATCH कमांड का एक संयोजन है।
Neo4j CQL MERGE कमांड ग्राफ़ में दिए गए पैटर्न की खोज करता है। यदि यह मौजूद है, तो यह परिणाम लौटाता है।
यदि यह ग्राफ़ में मौजूद नहीं है, तो यह एक नया नोड / संबंध बनाता है और परिणाम लौटाता है।
इस अध्याय में आप सीखेंगे कि कैसे -
- लेबल के साथ एक नोड मर्ज करें
- गुणों के साथ एक नोड मर्ज करें
- OnCreate और OnMatch
- किसी रिश्ते को मिला लें
वाक्य - विन्यास
निम्नलिखित MERGE कमांड के लिए सिंटैक्स है।
MERGE (node: label {properties . . . . . . . })
इस खंड में उदाहरणों पर आगे बढ़ने से पहले, धवन और इंडस्ट्रीज़ के साथ डेटाबेस में दो नोड बनाएं। नीचे दिखाए गए अनुसार, धवन से इंडस्ट्रीज़ के लिए "BATSMAN_OF" प्रकार का एक संबंध बनाएँ।
CREATE (Dhawan:player{name: "Shikar Dhawan", YOB: 1985, POB: "Delhi"})
CREATE (Ind:Country {name: "India"})
CREATE (Dhawan)-[r:BATSMAN_OF]->(Ind)
एक लेबल के साथ एक नोड विलय
आप MERGE क्लॉज का उपयोग करके लेबल के आधार पर डेटाबेस में एक नोड को मर्ज कर सकते हैं। यदि आप लेबल के आधार पर नोड को मर्ज करने का प्रयास करते हैं, तो Neo4j सत्यापित करता है कि दिए गए लेबल के साथ कोई नोड मौजूद है या नहीं। यदि नहीं, तो वर्तमान नोड बनाया जाएगा।
वाक्य - विन्यास
एक लेबल के आधार पर नोड को मर्ज करने के लिए सिंटैक्स निम्नलिखित है।
MERGE (node:label) RETURN node
उदाहरण 1
निम्नलिखित एक नमूना Cypher क्वेरी है जो Neo4j (लेबल के आधार पर) में एक नोड का विलय करता है। जब आप इस क्वेरी को निष्पादित करते हैं, Neo4j सत्यापित करता है कि क्या लेबल के साथ कोई नोड हैplayer। यदि नहीं, तो यह "जडेजा" नाम का एक नोड बनाता है और इसे लौटाता है।
यदि, दिए गए लेबल के साथ कोई नोड मौजूद है, Neo4j उन सभी को वापस करता है।
MERGE (Jadeja:player) RETURN Jadeja
उपरोक्त क्वेरी निष्पादित करने के लिए, निम्न चरणों का पालन करें -
Step 1- Neo4j डेस्कटॉप ऐप खोलें और Neo4j सर्वर शुरू करें। URL का उपयोग करके Neo4j का अंतर्निहित ब्राउज़र ऐप खोलेंhttp://localhost:7474/ जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।
Step 2 - डॉलर प्रॉम्प्ट में वांछित क्वेरी को कॉपी और पेस्ट करें और निम्न स्क्रीनशॉट में हाइलाइट किए गए प्ले बटन (क्वेरी को निष्पादित करने के लिए) दबाएं।
परिणाम
निष्पादित करने पर, आपको निम्नलिखित परिणाम मिलेगा। चूंकि आपने पहले ही डेटाबेस में लेबल "प्लेयर" के साथ "धवन" नाम का एक नोड बना लिया है, Neo4j इसे निम्न स्क्रीनशॉट में दिखाया गया है।
उदाहरण 2
अब, टूर्नामेंट नाम के लेबल के साथ "CT2013" नामक नोड को मर्ज करने का प्रयास करें। चूंकि इस लेबल के साथ कोई नोड नहीं हैं, Neo4j दिए गए नाम के साथ एक नोड बनाता है और इसे वापस करता है।
MERGE (CT2013:Tournament{name: "ICC Champions Trophy 2013"})
RETURN CT2013, labels(CT2013)
उपरोक्त क्वेरी निष्पादित करने के लिए, निम्न चरणों का पालन करें -
Step 1- Neo4j डेस्कटॉप ऐप खोलें और Neo4j सर्वर शुरू करें। URL का उपयोग करके Neo4j का अंतर्निहित ब्राउज़र ऐप खोलेंhttp://localhost:7474/ जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।
Step 2 - डॉलर प्रॉम्प्ट में वांछित क्वेरी को कॉपी और पेस्ट करें और निम्न स्क्रीनशॉट में हाइलाइट किए गए प्ले बटन (क्वेरी को निष्पादित करने के लिए) दबाएं।
परिणाम
निष्पादित करने पर, आपको निम्नलिखित परिणाम मिलेगा। जैसा कि चर्चा है, चूंकि दिए गए लेबल (टूर्नामेंट) के साथ कोई नोड नहीं है। Neo4j निम्न स्क्रीनशॉट में दिखाए गए अनुसार निर्दिष्ट नोड बनाता और वापस करता है।
गुणों के साथ एक नोड विलय
आप गुणों के एक सेट के साथ एक नोड को भी मर्ज कर सकते हैं। यदि आप ऐसा करते हैं, Neo4j गुणों सहित निर्दिष्ट नोड के लिए एक समान मैच की खोज करता है। यदि इसे कोई नहीं मिलता है, तो यह एक बनाता है।
वाक्य - विन्यास
गुणों का उपयोग करके नोड को मर्ज करने के लिए सिंटैक्स निम्नलिखित है।
MERGE (node:label {key1:value, key2:value, key3:value . . . . . . . . })
उदाहरण
गुणों का उपयोग करके नोड को मर्ज करने के लिए एक नमूना Cypher क्वेरी है। यह क्वेरी गुणों और लेबल का उपयोग करके "जडेजा" नाम के नोड को मर्ज करने की कोशिश करती है। चूंकि सटीक लेबल और गुणों के साथ ऐसा कोई नोड नहीं है, Neo4j एक बनाता है।
MERGE (Jadeja:player {name: "Ravindra Jadeja", YOB: 1988, POB: "NavagamGhed"})
RETURN Jadeja
उपरोक्त क्वेरी निष्पादित करने के लिए, निम्न चरणों का पालन करें -
Step 1- Neo4j डेस्कटॉप ऐप खोलें और Neo4j सर्वर शुरू करें। URL का उपयोग करके Neo4j का अंतर्निहित ब्राउज़र ऐप खोलेंhttp://localhost:7474/ जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।
Step 2 - डॉलर प्रॉम्प्ट में वांछित क्वेरी को कॉपी और पेस्ट करें और निम्न स्क्रीनशॉट में हाइलाइट किए गए प्ले बटन (क्वेरी को निष्पादित करने के लिए) दबाएं।
परिणाम
निष्पादित करने पर, आपको निम्नलिखित परिणाम मिलेगा। जैसा कि चर्चा है, चूंकि निर्दिष्ट लेबल और गुणों के साथ कोई नोड नहीं हैं, यह एक बनाता है, जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।
OnCreate और OnMatch
जब भी, हम एक मर्ज क्वेरी निष्पादित करते हैं, एक नोड या तो मिलान या बनाया जाता है। Create and on match का उपयोग करके, आप यह इंगित करने के लिए गुण सेट कर सकते हैं कि नोड बनाया गया है या मिलान किया गया है।
वाक्य - विन्यास
निम्नलिखित का सिंटैक्स है OnCreate तथा OnMatch खंड।
MERGE (node:label {properties . . . . . . . . . . .})
ON CREATE SET property.isCreated ="true"
ON MATCH SET property.isFound ="true"
उदाहरण
निम्नलिखित एक नमूना Cypher क्वेरी है जो के उपयोग को दर्शाता है OnCreate तथा OnMatchNeo4j में खंड। यदि निर्दिष्ट नोड पहले से ही डेटाबेस में मौजूद है, तो नोड का मिलान किया जाएगा और कुंजी-मूल्य जोड़ी के साथ गुणफल = "सही" नोड में बनाया जाएगा।
यदि निर्दिष्ट नोड डेटाबेस में मौजूद नहीं है, तो नोड बनाया जाएगा, और इसके भीतर एक कुंजी-मूल्य जोड़ी के साथ एक संपत्ति बनाई गई है = "सही" बनाया जाएगा।
MERGE (Jadeja:player {name: "Ravindra Jadeja", YOB: 1988, POB: "NavagamGhed"})
ON CREATE SET Jadeja.isCreated = "true"
ON MATCH SET Jadeja.isFound = "true"
RETURN Jadeja
उपरोक्त क्वेरी निष्पादित करने के लिए, निम्न चरणों का पालन करें -
Step 1- Neo4j डेस्कटॉप ऐप खोलें और Neo4j सर्वर शुरू करें। URL का उपयोग करके Neo4j का अंतर्निहित ब्राउज़र ऐप खोलेंhttp://localhost:7474/ जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।
Step 2 - डॉलर प्रॉम्प्ट में वांछित क्वेरी को कॉपी और पेस्ट करें और निम्न स्क्रीनशॉट में हाइलाइट किए गए प्ले बटन (क्वेरी को निष्पादित करने के लिए) दबाएं।
परिणाम
निष्पादित करने पर, आपको निम्नलिखित परिणाम मिलेगा। जैसा कि चर्चा है, चूंकि निर्दिष्ट विवरण के साथ कोई नोड नहीं है, Neo4j ने इसे संपत्ति के साथ बनायाisFound जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।
एक रिश्ता जोड़ो
नोड्स की तरह, आप भी MERGE क्लॉज का उपयोग करके रिश्तों को मर्ज कर सकते हैं।
उदाहरण
निम्नलिखित एक नमूना Cypher Query है जो Neo4j में MATCH क्लॉज का उपयोग करके एक संबंध बनाता है। यह क्वेरी नाम के संबंध को मर्ज करने का प्रयास करती हैWINNERS_OF नोड्स के बीच "इंडस्ट्रीज़" (लेबल: देश और नाम: भारत) और ICC13 (लेबल: टूर्नामेंट और नाम: आईसीसी चैंपियंस ट्रॉफी 2013)।
चूंकि इस तरह के संबंध मौजूद नहीं हैं, Neo4j एक बनाता है।
MATCH (a:Country), (b:Tournament)
WHERE a.name = "India" AND b.name = "ICC Champions Trophy 2013"
MERGE (a)-[r:WINNERS_OF]->(b)
RETURN a, b
उपरोक्त क्वेरी निष्पादित करने के लिए, निम्न चरणों का पालन करें -
Step 1- Neo4j डेस्कटॉप ऐप खोलें और Neo4j सर्वर शुरू करें। URL का उपयोग करके Neo4j का अंतर्निहित ब्राउज़र ऐप खोलेंhttp://localhost:7474/ जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।
Step 2 - डॉलर प्रॉम्प्ट में वांछित क्वेरी को कॉपी और पेस्ट करें और निम्न स्क्रीनशॉट में हाइलाइट किए गए प्ले बटन (क्वेरी को निष्पादित करने के लिए) दबाएं।
परिणाम
निष्पादित करने पर, आपको निम्नलिखित परिणाम मिलेगा। चूंकि निर्दिष्ट संबंध डेटाबेस में मौजूद नहीं है, Neo4j निम्न स्क्रीनशॉट में दिखाए अनुसार एक बनाता है।
उसी तरह, आप कई रिश्तों और अप्रत्यक्ष रिश्तों को भी मिला सकते हैं।
सेट क्लॉज़ का उपयोग करके, आप एक मौजूदा नोड या रिलेशनशिप में नए गुण जोड़ सकते हैं, और मौजूदा गुण मानों को जोड़ या अपडेट भी कर सकते हैं।
इस अध्याय में, हम चर्चा करेंगे कि कैसे -
- एक संपत्ति सेट करें
- एक संपत्ति निकालें
- कई गुण सेट करें
- नोड पर एक लेबल सेट करें
- एक नोड पर कई लेबल सेट करें
एक संपत्ति सेट करना
SET क्लॉज का उपयोग करके, आप एक नोड में एक नई संपत्ति बना सकते हैं।
वाक्य - विन्यास
संपत्ति सेट करने के लिए सिंटैक्स निम्नलिखित है।
MATCH (node:label{properties . . . . . . . . . . . . . . })
SET node.property = value
RETURN node
उदाहरण
उदाहरण के साथ आगे बढ़ने से पहले, पहले नीचे दिखाए गए अनुसार धवन नाम का एक नोड बनाएं।
CREATE (Dhawan:player{name: "shikar Dhawan", YOB: 1985, POB: "Delhi"})
निम्नलिखित एक नमूना साइफर क्वेरी है जिसका मूल्य "187" के साथ "हाईस्टकोरकोर" नाम की संपत्ति है ।
MATCH (Dhawan:player{name: "shikar Dhawan", YOB: 1985, POB: "Delhi"})
SET Dhawan.highestscore = 187
RETURN Dhawan
उपरोक्त क्वेरी निष्पादित करने के लिए, निम्न चरणों का पालन करें -
Step 1- Neo4j डेस्कटॉप ऐप खोलें और Neo4j सर्वर शुरू करें। URL का उपयोग करके Neo4j का अंतर्निहित ब्राउज़र ऐप खोलेंhttp://localhost:7474/ जैसा कि निम्नलिखित विवरण में दिखाया गया है।
Step 2 - डॉलर प्रॉम्प्ट में वांछित क्वेरी को कॉपी और पेस्ट करें और निम्न स्क्रीनशॉट में हाइलाइट किए गए प्ले बटन (क्वेरी को निष्पादित करने के लिए) दबाएं।
परिणाम
निष्पादित करने पर, आपको निम्नलिखित परिणाम मिलेगा। यहां आप देख सकते हैं कि "धवन" नाम के नोड में एक मुख्य-मूल्य जोड़ी हाईस्टकोर / 187 के साथ एक संपत्ति बनाई गई है।
एक संपत्ति निकालना
आप मौजूदा संपत्ति को पास करके निकाल सकते हैं NULL इसके मूल्य के रूप में।
वाक्य - विन्यास
SET क्लॉज का उपयोग करके किसी प्रॉपर्टी को नोड से हटाने का सिंटैक्स निम्नलिखित है।
MATCH (node:label {properties})
SET node.property = NULL
RETURN node
उदाहरण
उदाहरण के साथ आगे बढ़ने से पहले, पहले एक नोड "जडेजा" बनाएं जैसा कि नीचे दिखाया गया है।
Create (Jadeja:player {name: "Ravindra Jadeja", YOB: 1988, POB: "NavagamGhed"})
निम्नलिखित एक नमूना Cypher क्वेरी है जो नीचे दिखाए गए अनुसार SET क्लॉज का उपयोग करके इस नोड से POB नामक संपत्ति को हटाता है।
MATCH (Jadeja:player {name: "Ravindra Jadeja", YOB: 1988, POB: "NavagamGhed"})
SET Jadeja.POB = NULL
RETURN Jadeja
उपरोक्त क्वेरी निष्पादित करने के लिए, निम्न चरणों का पालन करें -
Step 1- Neo4j डेस्कटॉप ऐप खोलें और Neo4j सर्वर शुरू करें। URL का उपयोग करके Neo4j का अंतर्निहित ब्राउज़र ऐप खोलेंhttp://localhost:7474/ जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।
Step 2 - डॉलर प्रॉम्प्ट में वांछित क्वेरी को कॉपी और पेस्ट करें और निम्न स्क्रीनशॉट में हाइलाइट किए गए प्ले बटन (क्वेरी को निष्पादित करने के लिए) दबाएं।
परिणाम
निष्पादित करने पर, आपको निम्नलिखित परिणाम मिलेगा। यहां आप देख सकते हैं कि नामित चरPOB हटाया गया था।
कई गुण स्थापित करना
उसी तरह, आप सेट क्लॉज का उपयोग करके नोड में कई गुण बना सकते हैं। ऐसा करने के लिए, आपको कॉमा के साथ इन प्रमुख मूल्य जोड़े को निर्दिष्ट करने की आवश्यकता है।
वाक्य - विन्यास
SET क्लॉज का उपयोग करके नोड में कई गुण बनाने के लिए सिंटैक्स निम्नलिखित है।
MATCH (node:label {properties})
SET node.property1 = value, node.property2 = value
RETURN node
उदाहरण
निम्नलिखित एक नमूना Cypher क्वेरी है जो Neo4j में SET क्लॉज का उपयोग करके नोड में कई गुण बनाता है।
MATCH (Jadeja:player {name: "Ravindra Jadeja", YOB: 1988})
SET Jadeja.POB: "NavagamGhed", Jadeja.HS = "90"
RETURN Jadeja
उपरोक्त क्वेरी निष्पादित करने के लिए, निम्न चरणों का पालन करें -
Step 1- Neo4j डेस्कटॉप ऐप खोलें और Neo4j सर्वर शुरू करें। URL का उपयोग करके Neo4j का अंतर्निहित ब्राउज़र ऐप खोलेंhttp://localhost:7474/ जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।
Step 2 - डॉलर प्रॉम्प्ट में वांछित क्वेरी को कॉपी और पेस्ट करें और निम्न स्क्रीनशॉट में हाइलाइट किए गए प्ले बटन (क्वेरी को निष्पादित करने के लिए) दबाएं।
परिणाम
निष्पादित करने पर, आपको निम्नलिखित परिणाम मिलेगा। यहां आप देख सकते हैं कि POB और HS नामक गुण बनाए गए थे।
एक नोड पर एक लेबल सेट करना
आप सेट खंड का उपयोग करके मौजूदा नोड पर एक लेबल सेट कर सकते हैं।
वाक्य - विन्यास
एक मौजूदा नोड में एक लेबल सेट करने के लिए सिंटैक्स निम्नलिखित है।
MATCH (n {properties . . . . . . . })
SET n :label
RETURN n
उदाहरण
उदाहरण के साथ आगे बढ़ने से पहले, पहले एक नोड "एंडरसन" बनाएं जैसा कि नीचे दिखाया गया है।
CREATE (Anderson {name: "James Anderson", YOB: 1982, POB: "Burnely"})
SET क्लॉज का उपयोग करके नोड पर एक लेबल सेट करने के लिए एक नमूना Cypher क्वेरी है। यह क्वेरी लेबल "खिलाड़ी" को नोड एंडरसन में जोड़ता है और इसे वापस करता है।
MATCH (Anderson {name: "James Anderson", YOB: 1982, POB: "Burnely"})
SET Anderson: player
RETURN Anderson
उपरोक्त क्वेरी निष्पादित करने के लिए, निम्न चरणों का पालन करें -
Step 1- Neo4j डेस्कटॉप ऐप खोलें और Neo4j सर्वर शुरू करें। URL का उपयोग करके Neo4j का अंतर्निहित ब्राउज़र ऐप खोलेंhttp://localhost:7474/ जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।
Step 2 - डॉलर प्रॉम्प्ट में वांछित क्वेरी को कॉपी और पेस्ट करें और निम्न स्क्रीनशॉट में हाइलाइट किए गए प्ले बटन (क्वेरी को निष्पादित करने के लिए) दबाएं।
परिणाम
निष्पादित करने पर, आपको निम्नलिखित परिणाम मिलेगा। यहां आप देख सकते हैं कि "प्लेयर" नाम का लेबल नोड में जोड़ा गया है।
एक नोड पर कई लेबल सेट करना
आप SET क्लॉज का उपयोग करके एक मौजूदा नोड में कई लेबल सेट कर सकते हैं। यहां आपको लेबल को "कॉलोन" के साथ अलग करके निर्दिष्ट करने की आवश्यकता है।
वाक्य - विन्यास
SET क्लॉज का उपयोग करके एक मौजूदा नोड में कई लेबल सेट करने के लिए सिंटैक्स है।
MATCH (n {properties . . . . . . . })
SET n :label1:label2
RETURN n
उदाहरण
उदाहरण के साथ आगे बढ़ने से पहले, पहले "इशांत" नाम का एक नोड बनाएं, जैसा कि नीचे दिखाया गया है।
CREATE (Ishant {name: "Ishant Sharma", YOB: 1988, POB: "Delhi"})
निम्नलिखित एक नमूना Cypher क्वेरी SET क्लॉज का उपयोग करके नोड पर कई लेबल बनाने के लिए उपयोग किया जाता है।
MATCH (Ishant {name: "Ishant Sharma", YOB: 1988, POB: "Delhi"})
SET Ishant: player:person
RETURN Ishant
उपरोक्त क्वेरी निष्पादित करने के लिए, निम्न चरणों का पालन करें -
Step 1- Neo4j डेस्कटॉप ऐप खोलें और Neo4j सर्वर शुरू करें। URL का उपयोग करके Neo4j का अंतर्निहित ब्राउज़र ऐप खोलेंhttp://localhost:7474/ जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।
Step 2 - डॉलर प्रॉम्प्ट में वांछित क्वेरी को कॉपी और पेस्ट करें और निम्न स्क्रीनशॉट में हाइलाइट किए गए प्ले बटन (क्वेरी को निष्पादित करने के लिए) दबाएं।
परिणाम
निष्पादित करने पर, आपको निम्नलिखित परिणाम मिलेगा। यहां आप देख सकते हैं कि दो लेबल - व्यक्ति और खिलाड़ी - नाम के नोड में जोड़े जाते हैंIshant।
आप DELETE क्लॉज का उपयोग करके डेटाबेस से नोड्स और रिश्तों को हटा सकते हैं।
सभी नोड्स और संबंध हटाना
DELETE क्लॉज का उपयोग करके डेटाबेस में सभी नोड्स और रिश्तों को हटाने की क्वेरी निम्नलिखित है।
सवाल
MATCH (n) DETACH DELETE n
उपरोक्त क्वेरी निष्पादित करने के लिए, निम्न चरणों का पालन करें -
Step 1- Neo4j डेस्कटॉप ऐप खोलें और Neo4j सर्वर शुरू करें। URL का उपयोग करके Neo4j का अंतर्निहित ब्राउज़र ऐप खोलेंhttp://localhost:7474/ जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।
Step 2 - डॉलर प्रॉम्प्ट में वांछित क्वेरी को कॉपी और पेस्ट करें और निम्न स्क्रीनशॉट में हाइलाइट किए गए प्ले बटन (क्वेरी को निष्पादित करने के लिए) दबाएं।
यह आपके neo4j डेटाबेस से सभी नोड्स और संबंधों को हटा देगा और इसे खाली कर देगा।
एक विशेष नोड को हटाना
किसी विशेष नोड को हटाने के लिए, आपको उपरोक्त क्वेरी में "n" के स्थान पर नोड का विवरण निर्दिष्ट करना होगा।
वाक्य - विन्यास
निम्नलिखित DELETE क्लॉज का उपयोग करके Neo4j से एक विशेष नोड को हटाने के लिए सिंटैक्स है।
MATCH (node:label {properties . . . . . . . . . . })
DETACH DELETE node
उदाहरण
उदाहरण के साथ आगे बढ़ने से पहले Neo4j डेटाबेस में एक नोड "इशांत" बनाएं जैसा कि नीचे दिखाया गया है।
CREATE (Ishant:player {name: "Ishant Sharma", YOB: 1988, POB: "Delhi"})
निम्नलिखित एक नमूना Cypher Query है जो DELETE क्लॉज का उपयोग करके उपर्युक्त नोड को हटाता है।
MATCH (Ishant:player {name: "Ishant Sharma", YOB: 1988, POB: "Delhi"})
DETACH DELETE Ishant
उपरोक्त क्वेरी निष्पादित करने के लिए, निम्न चरणों का पालन करें -
Step 1- Neo4j डेस्कटॉप ऐप खोलें और Neo4j सर्वर शुरू करें। URL का उपयोग करके Neo4j का अंतर्निहित ब्राउज़र ऐप खोलेंhttp://localhost:7474/ जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।
Step 2 - डॉलर प्रॉम्प्ट में वांछित क्वेरी को कॉपी और पेस्ट करें और निम्न स्क्रीनशॉट में हाइलाइट किए गए प्ले बटन (क्वेरी को निष्पादित करने के लिए) दबाएं।
परिणाम
निष्पादित करने पर, आपको निम्नलिखित परिणाम मिलेगा। यहां आप देख सकते हैं कि निर्दिष्ट नोड हटा दिया गया है।
REMOVE क्लॉज का उपयोग ग्राफ तत्वों (नोड्स या रिलेशनशिप) से गुण और लेबल हटाने के लिए किया जाता है।
Neo4j CQL DELETE और REMOVE कमांड के बीच मुख्य अंतर है -
- DELETE ऑपरेशन का उपयोग नोड्स और संबंधित रिश्तों को हटाने के लिए किया जाता है।
- REMOVE ऑपरेशन का इस्तेमाल लेबल और प्रॉपर्टी को हटाने के लिए किया जाता है।
एक संपत्ति निकालना
आप REMOVE क्लॉज के साथ MATCH का उपयोग करके एक नोड की संपत्ति को हटा सकते हैं।
वाक्य - विन्यास
REMOVE क्लॉज का उपयोग करके नोड की संपत्ति को निकालने के लिए सिंटैक्स निम्नलिखित है।
MATCH (node:label{properties . . . . . . . })
REMOVE node.property
RETURN node
उदाहरण
उदाहरण के साथ आगे बढ़ने से पहले, नाम का एक नोड बनाएं Dhoni जैसा की नीचे दिखाया गया।
CREATE (Dhoni:player {name: "MahendraSingh Dhoni", YOB: 1981, POB: "Ranchi"})
REMOVE क्लॉज का उपयोग करके उपरोक्त बनाए गए नोड को हटाने के लिए एक नमूना Cypher क्वेरी है।
MATCH (Dhoni:player {name: "MahendraSingh Dhoni", YOB: 1981, POB: "Ranchi"})
REMOVE Dhoni.POB
RETURN Dhoni
उपरोक्त क्वेरी निष्पादित करने के लिए, निम्न चरणों का पालन करें -
Step 1- Neo4j डेस्कटॉप ऐप खोलें और Neo4j सर्वर शुरू करें। URL का उपयोग करके Neo4j का अंतर्निहित ब्राउज़र ऐप खोलेंhttp://localhost:7474/ जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।
Step 2 - डॉलर प्रॉम्प्ट में वांछित क्वेरी को कॉपी और पेस्ट करें और निम्न स्क्रीनशॉट में हाइलाइट किए गए प्ले बटन (क्वेरी को निष्पादित करने के लिए) दबाएं।
परिणाम
निष्पादित करने पर, आपको निम्नलिखित परिणाम मिलेगा। यहां, आप देख सकते हैं कि POB नाम का नोड हटा दिया गया था।
एक नोड से एक लेबल हटाना
संपत्ति के समान, आप हटाए गए खंड का उपयोग करके मौजूदा नोड से एक लेबल भी निकाल सकते हैं।
वाक्य - विन्यास
एक नोड से एक लेबल को हटाने के लिए सिंटैक्स निम्नलिखित है।
MATCH (node:label {properties . . . . . . . . . . . })
REMOVE node:label
RETURN node
उदाहरण
निम्नलिखित खंड का उपयोग करके एक मौजूदा नोड से एक लेबल को हटाने के लिए एक नमूना Cypher क्वेरी है।
MATCH (Dhoni:player {name: "MahendraSingh Dhoni", YOB: 1981, POB: "Ranchi"})
REMOVE Dhoni:player
RETURN Dhoni
उपरोक्त क्वेरी निष्पादित करने के लिए, निम्न चरणों का पालन करें -
Step 1- Neo4j डेस्कटॉप ऐप खोलें और Neo4j सर्वर शुरू करें। URL का उपयोग करके Neo4j का अंतर्निहित ब्राउज़र ऐप खोलेंhttp://localhost:7474/ जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।
Step 2 - डॉलर प्रॉम्प्ट में वांछित क्वेरी को कॉपी और पेस्ट करें और निम्न स्क्रीनशॉट में हाइलाइट किए गए प्ले बटन (क्वेरी को निष्पादित करने के लिए) दबाएं।
परिणाम
निष्पादित करने पर, आपको निम्नलिखित परिणाम मिलेगा। यहां, आप देख सकते हैं कि लेबल नोड से हटा दिया गया था।
कई लेबल हटाना
आप एक मौजूदा नोड से कई लेबल भी निकाल सकते हैं।
वाक्य - विन्यास
एक नोड से कई लेबल हटाने के लिए सिंटैक्स निम्नलिखित है।
MATCH (node:label1:label2 {properties . . . . . . . . })
REMOVE node:label1:label2
RETURN node
उदाहरण
उदाहरण के साथ आगे बढ़ने से पहले, नीचे दिखाए अनुसार एक नोड ईशांत बनाएं।
CREATE (Ishant:player:person {name: "Ishant Sharma", YOB: 1988, POB: "Delhi"})
एक नोड से कई लेबल हटाने के लिए एक नमूना Cypher क्वेरी है।
MATCH (Ishant:player:person {name: "Ishant Sharma", YOB: 1988, POB: "Delhi"})
REMOVE Ishant:player:person
RETURN Ishant
उपरोक्त क्वेरी निष्पादित करने के लिए, निम्न चरणों का पालन करें -
Step 1- Neo4j डेस्कटॉप ऐप खोलें और Neo4j सर्वर शुरू करें। URL का उपयोग करके Neo4j का अंतर्निहित ब्राउज़र ऐप खोलेंhttp://localhost:7474/ जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।
Step 2 - डॉलर प्रॉम्प्ट में वांछित क्वेरी को कॉपी और पेस्ट करें और निम्न स्क्रीनशॉट में हाइलाइट किए गए प्ले बटन (क्वेरी को निष्पादित करने के लिए) दबाएं।
परिणाम
निष्पादित करने पर, आपको निम्नलिखित परिणाम मिलेगा। यहां, आप देख सकते हैं कि निर्दिष्ट लेबल नोड से हटा दिए गए थे।
FOREACH क्लॉज का उपयोग किसी सूची के डेटा को अपडेट करने के लिए किया जाता है, चाहे पथ के घटक, या एकत्रीकरण का परिणाम।
वाक्य - विन्यास
निम्नलिखित FOREACH खंड का सिंटैक्स है।
MATCH p = (start node)-[*]->(end node)
WHERE start.node = "node_name" AND end.node = "node_name"
FOREACH (n IN nodes(p)| SET n.marked = TRUE)
उदाहरण
उदाहरण के साथ आगे बढ़ने से पहले, एक पथ बनाएं p नीचे दिखाए गए अनुसार Neo4j डेटाबेस में।
CREATE p = (Dhawan {name:"Shikar Dhawan"})-[:TOPSCORRER_OF]->(Ind{name:
"India"})-[:WINNER_OF]->(CT2013{name: "Champions Trophy 2013"})
RETURN p
निम्नलिखित एक नमूना Cypher Query है जो FOREACH क्लॉज का उपयोग करते हुए रास्ते में सभी नोड्स के लिए एक संपत्ति जोड़ता है।
MATCH p = (Dhawan)-[*]->(CT2013)
WHERE Dhawan.name = "Shikar Dhawan" AND CT2013.name = "Champions Trophy 2013"
FOREACH (n IN nodes(p)| SET n.marked = TRUE)
उपरोक्त क्वेरी निष्पादित करने के लिए, निम्न चरणों का पालन करें -
Step 1- Neo4j डेस्कटॉप ऐप खोलें और Neo4j सर्वर शुरू करें। URL का उपयोग करके Neo4j का अंतर्निहित ब्राउज़र ऐप खोलेंhttp://localhost:7474/ जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।
Step 2 - डॉलर प्रॉम्प्ट में वांछित क्वेरी को कॉपी और पेस्ट करें और निम्न स्क्रीनशॉट में हाइलाइट किए गए प्ले बटन (क्वेरी को निष्पादित करने के लिए) दबाएं।
परिणाम
निष्पादित करने पर, आपको निम्नलिखित परिणाम मिलेगा।
सत्यापन
नोड के निर्माण को सत्यापित करने के लिए, डॉलर प्रांप्ट में निम्नलिखित क्वेरी टाइप करें और निष्पादित करें।
MATCH (n) RETURN n
यह क्वेरी डेटाबेस में सभी नोड्स देता है (हम आने वाले अध्यायों में इस क्वेरी के बारे में विस्तार से चर्चा करेंगे)।
निष्पादित करने पर, यह क्वेरी बनाई गई नोड को दिखाती है जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।
इस अध्याय में, हम मैच क्लॉज और उन सभी कार्यों के बारे में जानेंगे जो इस क्लॉज का उपयोग करके किए जा सकते हैं।
मैच का उपयोग कर सभी नोड्स प्राप्त करें
Neo4j के MATCH क्लॉज का उपयोग करके आप Neo4j डेटाबेस में सभी नोड्स पुनः प्राप्त कर सकते हैं।
उदाहरण
उदाहरण के साथ आगे बढ़ने से पहले, नीचे दिखाए गए अनुसार 3 नोड और 2 संबंध बनाएं।
CREATE (Dhoni:player {name: "MahendraSingh Dhoni", YOB: 1981, POB: "Ranchi"})
CREATE (Ind:Country {name: "India", result: "Winners"})
CREATE (CT2013:Tornament {name: "ICC Champions Trophy 2013"})
CREATE (Ind)-[r1:WINNERS_OF {NRR:0.938 ,pts:6}]->(CT2013)
CREATE(Dhoni)-[r2:CAPTAIN_OF]->(Ind)
CREATE (Dhawan:player{name: "shikar Dhawan", YOB: 1995, POB: "Delhi"})
CREATE (Jadeja:player {name: "Ravindra Jadeja", YOB: 1988, POB: "NavagamGhed"})
CREATE (Dhawan)-[:TOP_SCORER_OF {Runs:363}]->(Ind)
CREATE (Jadeja)-[:HIGHEST_WICKET_TAKER_OF {Wickets:12}]->(Ind)
निम्नलिखित क्वेरी है जो Neo4j डेटाबेस में सभी नोड्स लौटाती है।
MATCH (n) RETURN n
उपरोक्त क्वेरी निष्पादित करने के लिए, निम्न चरणों का पालन करें -
Step 1- Neo4j डेस्कटॉप ऐप खोलें और Neo4j सर्वर शुरू करें। URL का उपयोग करके Neo4j का अंतर्निहित ब्राउज़र ऐप खोलेंhttp://localhost:7474/ जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।
Step 2 - डॉलर प्रॉम्प्ट में वांछित क्वेरी को कॉपी और पेस्ट करें और निम्न स्क्रीनशॉट में हाइलाइट किए गए प्ले बटन (क्वेरी को निष्पादित करने के लिए) दबाएं।
परिणाम
निष्पादित करने पर, आपको निम्नलिखित परिणाम मिलेगा।
एक विशिष्ट लेबल के तहत सभी नोड्स प्राप्त करना
मैच क्लॉज का उपयोग करके, आप एक विशिष्ट लेबल के तहत सभी नोड प्राप्त कर सकते हैं।
वाक्य - विन्यास
निम्नलिखित एक विशिष्ट लेबल के तहत सभी नोड्स प्राप्त करने के लिए वाक्यविन्यास है।
MATCH (node:label)
RETURN node
उदाहरण
निम्नलिखित एक नमूना साइफ्री क्वेरी है, जो लेबल के तहत डेटाबेस में सभी नोड्स लौटाता है player।
MATCH (n:player)
RETURN n
उपरोक्त क्वेरी निष्पादित करने के लिए, निम्न चरणों का पालन करें -
Step 1- Neo4j डेस्कटॉप ऐप खोलें और Neo4j सर्वर शुरू करें। URL का उपयोग करके Neo4j का अंतर्निहित ब्राउज़र ऐप खोलेंhttp://localhost:7474/ जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।
Step 2 - डॉलर प्रॉम्प्ट में वांछित क्वेरी को कॉपी और पेस्ट करें और निम्न स्क्रीनशॉट में हाइलाइट किए गए प्ले बटन (क्वेरी को निष्पादित करने के लिए) दबाएं।
परिणाम
निष्पादित करने पर, आपको निम्नलिखित परिणाम मिलेगा।
रिश्ते से मेल
आप MATCH क्लॉज का उपयोग करके रिश्ते के आधार पर नोड प्राप्त कर सकते हैं।
वाक्य - विन्यास
निम्नलिखित MATCH क्लॉज का उपयोग करके संबंध के आधार पर नोड्स को पुनः प्राप्त करने का सिंटैक्स है।
MATCH (node:label)<-[: Relationship]-(n)
RETURN n
उदाहरण
MATCH क्लॉज का उपयोग करके संबंध के आधार पर नोड्स को पुनः प्राप्त करने के लिए एक नमूना Cypher क्वेरी है।
MATCH (Ind:Country {name: "India", result: "Winners"})<-[: TOP_SCORER_OF]-(n)
RETURN n.name
उपरोक्त क्वेरी निष्पादित करने के लिए, निम्न चरणों का पालन करें -
Step 1- Neo4j डेस्कटॉप ऐप खोलें और Neo4j सर्वर शुरू करें। URL का उपयोग करके Neo4j का अंतर्निहित ब्राउज़र ऐप खोलेंhttp://localhost:7474/ जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।
Step 2 - डॉलर प्रॉम्प्ट में वांछित क्वेरी को कॉपी और पेस्ट करें और निम्न स्क्रीनशॉट में हाइलाइट किए गए प्ले बटन (क्वेरी को निष्पादित करने के लिए) दबाएं।
परिणाम
निष्पादित करने पर, आपको निम्नलिखित परिणाम मिलेगा।
सभी नोड्स हटाएँ
आप MATCH क्लॉज का उपयोग करके सभी नोड्स को हटा सकते हैं।
सवाल
निम्नलिखित Neo4j में सभी नोड्स को हटाने के लिए क्वेरी है।
MATCH (n) detach delete n
उपरोक्त क्वेरी निष्पादित करने के लिए, निम्न चरणों का पालन करें -
Step 1- Neo4j डेस्कटॉप ऐप खोलें और Neo4j सर्वर शुरू करें। URL का उपयोग करके Neo4j का अंतर्निहित ब्राउज़र ऐप खोलेंhttp://localhost:7474/ जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।
Step 2 - डॉलर प्रॉम्प्ट में वांछित क्वेरी को कॉपी और पेस्ट करें और निम्न स्क्रीनशॉट में हाइलाइट किए गए प्ले बटन (क्वेरी को निष्पादित करने के लिए) दबाएं।
परिणाम
निष्पादित करने पर, आपको निम्नलिखित परिणाम मिलेगा।
OPTIONAL MATCH क्लॉज का उपयोग पैटर्न के लापता भागों के लिए नल का उपयोग करते समय, इसमें वर्णित पैटर्न की खोज के लिए किया जाता है।
वैकल्पिक MATCH, मैच क्लॉज के समान है, एकमात्र अंतर यह है कि पैटर्न के लापता भागों के परिणामस्वरूप यह अशक्त हो जाता है।
वाक्य - विन्यास
निम्नलिखित संबंध के साथ वैकल्पिक सामग्री का वाक्यविन्यास है।
MATCH (node:label {properties. . . . . . . . . . . . . .})
OPTIONAL MATCH (node)-->(x)
RETURN x
उदाहरण
निम्नलिखित एक नमूना Cypher क्वेरी है जो नोड ICCT2013 से संबंधों को पुनः प्राप्त करने की कोशिश करता है। चूंकि इस तरह के नोड्स नहीं हैं, इसलिए यह अशक्त है।
MATCH (a:Tornament {name: "ICC Champions Trophy 2013"})
OPTIONAL MATCH (a)-->(x)
RETURN x
उपरोक्त क्वेरी निष्पादित करने के लिए, निम्न चरणों का पालन करें -
Step 1- Neo4j डेस्कटॉप ऐप खोलें और Neo4j सर्वर शुरू करें। URL का उपयोग करके Neo4j का अंतर्निहित ब्राउज़र ऐप खोलेंhttp://localhost:7474/ जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।
Step 2 - डॉलर प्रॉम्प्ट में वांछित क्वेरी को कॉपी और पेस्ट करें और निम्न स्क्रीनशॉट में हाइलाइट किए गए प्ले बटन (क्वेरी को निष्पादित करने के लिए) दबाएं।
परिणाम
निष्पादित करने पर, आपको निम्नलिखित परिणाम मिलेगा। यहां आप यह देख सकते हैं कि चूंकि आवश्यक पैटर्न के लिए कोई मैच नहीं हैं, Neo4j शून्य हो गया।
SQL की तरह, Neo4j CQL ने MATCH Query के परिणामों को फ़िल्टर करने के लिए CQL MATCH कमांड में WHERE क्लॉज प्रदान किया है।
वाक्य - विन्यास
निम्नलिखित WHERE क्लॉज का सिंटैक्स है।
MATCH (label)
WHERE label.country = "property"
RETURN label
उदाहरण
उदाहरण के साथ आगे बढ़ने से पहले, डेटाबेस में पांच नोड बनाएं जैसा कि नीचे दिखाया गया है।
CREATE(Dhawan:player{name:"shikar Dhawan", YOB: 1985, runs:363, country: "India"}
CREATE(Jonathan:player{name:"Jonathan Trott", YOB:1981, runs:229, country:"South Africa"}
CREATE(Sangakkara:player{name:"Kumar Sangakkara", YOB:1977, runs:222,
country:"Srilanka"})
CREATE(Rohit:player{name:"Rohit Sharma", YOB: 1987, runs:177, country:"India"})
CREATE(Virat:player{name:"Virat Kohli", YOB: 1988, runs:176, country:"India"})
CREATE(Ind:Country {name: "India", result: "Winners"})
निम्नलिखित एक नमूना Cypher Query है जो सभी खिलाड़ियों (नोड्स) को लौटाता है जो देश भारत से संबंधित है जहां WHERE क्लॉज का उपयोग किया जाता है।
MATCH (player)
WHERE player.country = "India"
RETURN player
उपरोक्त क्वेरी निष्पादित करने के लिए, निम्न चरणों का पालन करें -
Step 1- Neo4j डेस्कटॉप ऐप खोलें और Neo4j सर्वर शुरू करें। URL का उपयोग करके Neo4j का अंतर्निहित ब्राउज़र ऐप खोलेंhttp://localhost:7474/ जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।
Step 2 - डॉलर प्रॉम्प्ट में वांछित क्वेरी को कॉपी और पेस्ट करें और निम्न स्क्रीनशॉट में हाइलाइट किए गए प्ले बटन (क्वेरी को निष्पादित करने के लिए) दबाएं।
परिणाम
निष्पादित करने पर, आपको निम्नलिखित परिणाम मिलेगा।
जहां एकाधिक शर्तों के साथ खंड है
आप कई शर्तों को सत्यापित करने के लिए WHERE क्लॉज का उपयोग भी कर सकते हैं।
वाक्य - विन्यास
निम्न कई शर्तों के साथ Neo4j में WHERE क्लॉज का उपयोग करने के लिए सिंटैक्स है।
MATCH (emp:Employee)
WHERE emp.name = 'Abc' AND emp.name = 'Xyz'
RETURN emp
उदाहरण
निम्नलिखित एक नमूना Cypher Query है जो Neo4j डेटाबेस में दो स्थितियों का उपयोग करके नोड्स को फ़िल्टर करता है।
MATCH (player)
WHERE player.country = "India" AND player.runs >=175
RETURN player
उपरोक्त क्वेरी निष्पादित करने के लिए, निम्न चरणों का पालन करें -
Step 1- Neo4j डेस्कटॉप ऐप खोलें और Neo4j सर्वर शुरू करें। URL का उपयोग करके Neo4j का अंतर्निहित ब्राउज़र ऐप खोलेंhttp://localhost:7474/ जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।
Step 2 - डॉलर प्रॉम्प्ट में वांछित क्वेरी को कॉपी और पेस्ट करें और निम्न स्क्रीनशॉट में हाइलाइट किए गए प्ले बटन (क्वेरी को निष्पादित करने के लिए) दबाएं।
परिणाम
निष्पादित करने पर, आपको निम्नलिखित परिणाम मिलेगा।
जहां क्लॉज के साथ संबंध का उपयोग करना
आप रिश्तों का उपयोग करके नोड्स को फ़िल्टर करने के लिए कहाँ क्लॉज़ का उपयोग कर सकते हैं।
उदाहरण
मान लें कि हमारे पास डेटाबेस में निम्नलिखित ग्राफ है।
नीचे दिए गए अनुसार WHERE क्लॉज का उपयोग करके भारत के शीर्ष स्कोरर को पुनः प्राप्त करने के लिए एक नमूना Cypher Query है।
MATCH (n)
WHERE (n)-[: TOP_SCORER_OF]->( {name: "India", result: "Winners"})
RETURN n
उपरोक्त क्वेरी निष्पादित करने के लिए, निम्न चरणों का पालन करें -
Step 1- Neo4j डेस्कटॉप ऐप खोलें और Neo4j सर्वर शुरू करें। URL का उपयोग करके Neo4j का अंतर्निहित ब्राउज़र ऐप खोलेंhttp://localhost:7474/ जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।
Step 2 - डॉलर प्रॉम्प्ट में वांछित क्वेरी को कॉपी और पेस्ट करें और निम्न स्क्रीनशॉट में हाइलाइट किए गए प्ले बटन (क्वेरी को निष्पादित करने के लिए) दबाएं।
परिणाम
निष्पादित करने पर, आपको निम्नलिखित परिणाम मिलेगा। यहां आप देख सकते हैं कि Neo4j ने नोड लौटाया, जिसका संबंध भारत के नाम के साथ TOP_SCORER_OF देश से है।
मान लें कि हमने निम्नलिखित विवरण के साथ डेटाबेस में एक ग्राफ बनाया है।
गिनती
count() फ़ंक्शन का उपयोग पंक्तियों की संख्या को गिनने के लिए किया जाता है।
वाक्य - विन्यास
निम्नलिखित गणना फ़ंक्शन का सिंटैक्स है।
MATCH (n { name: 'A' })-->(x)
RETURN n, count(*)
उदाहरण
निम्नलिखित एक नमूना Cypher क्वेरी है जो के उपयोग को दर्शाता है count() समारोह।
Match(n{name: "India", result: "Winners"})--(x)
RETURN n, count(*)
उपरोक्त क्वेरी निष्पादित करने के लिए, निम्न चरणों का पालन करें -
Step 1- Neo4j डेस्कटॉप ऐप खोलें और Neo4j सर्वर शुरू करें। URL का उपयोग करके Neo4j का अंतर्निहित ब्राउज़र ऐप खोलेंhttp://localhost:7474/ जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।
Step 2 - डॉलर प्रॉम्प्ट में वांछित क्वेरी को कॉपी और पेस्ट करें और निम्न स्क्रीनशॉट में हाइलाइट किए गए प्ले बटन (क्वेरी को निष्पादित करने के लिए) दबाएं।
परिणाम
निष्पादित करने पर, आपको निम्नलिखित परिणाम मिलेगा।
समूह गणना
COUNT खंड का उपयोग संबंध प्रकारों के समूहों को गिनने के लिए भी किया जाता है।
उदाहरण
निम्नलिखित एक नमूना साइफर क्वेरी है जो प्रत्येक संबंध में भाग लेने वाले नोड्स की संख्या की गणना करता है और वापस करता है।
Match(n{name: "India", result: "Winners"})-[r]-(x)
RETURN type (r), count(*)
उपरोक्त क्वेरी निष्पादित करने के लिए, निम्न चरणों का पालन करें -
Step 1- Neo4j डेस्कटॉप ऐप खोलें और Neo4j सर्वर शुरू करें। URL का उपयोग करके Neo4j का अंतर्निहित ब्राउज़र ऐप खोलेंhttp://localhost:7474/ जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।
Step 2 - डॉलर प्रॉम्प्ट में वांछित क्वेरी को कॉपी और पेस्ट करें और निम्न स्क्रीनशॉट में हाइलाइट किए गए प्ले बटन (क्वेरी को निष्पादित करने के लिए) दबाएं।
RETURN क्लॉज का उपयोग Neo4j में रिटर्न नोड्स, रिलेशनशिप और प्रॉपर्टीज में किया जाता है। इस अध्याय में, हम सीखेंगे कि कैसे -
- नोड लौटें
- कई नोड्स लौटाएं
- रिश्तों को लौटाओ
- वापसी के गुण
- सभी तत्वों को वापस करें
- कॉलम उर्फ के साथ एक चर लौटें
लौटते हुए नोड्स
आप RETURN क्लॉज का उपयोग करके एक नोड वापस कर सकते हैं।
वाक्य - विन्यास
RETURN क्लॉज का उपयोग करके नोड्स वापस करने के लिए एक सिंटैक्स है।
Create (node:label {properties})
RETURN node
उदाहरण
उदाहरण के साथ आगे बढ़ने से पहले, नीचे दिखाए गए अनुसार 3 नोड और 2 संबंध बनाएं।
Create (Dhoni:player {name: "MahendraSingh Dhoni", YOB: 1981, POB: "Ranchi"})
CREATE (Ind:Country {name: "India", result: "Winners"})
CREATE (CT2013:Tornament {name: "ICC Champions Trophy 2013"})
CREATE (Ind)-[r1:WINNERS_OF {NRR:0.938 ,pts:6}]->(CT2013)
CREATE(Dhoni)-[r2:CAPTAIN_OF]->(Ind)
निम्नलिखित एक नमूना साइफ्री क्वेरी है जो धोनी नाम का एक नोड बनाता है और इसे वापस करता है।
Create (Dhoni:player {name: "MahendraSingh Dhoni", YOB: 1981, POB: "Ranchi"})
RETURN Dhoni
उपरोक्त क्वेरी निष्पादित करने के लिए, निम्न चरणों का पालन करें -
Step 1- Neo4j डेस्कटॉप ऐप खोलें और Neo4j सर्वर शुरू करें। URL का उपयोग करके Neo4j का अंतर्निहित ब्राउज़र ऐप खोलेंhttp://localhost:7474/ जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।
Step 2 - डॉलर प्रॉम्प्ट में वांछित क्वेरी को कॉपी और पेस्ट करें और निम्न स्क्रीनशॉट में हाइलाइट किए गए प्ले बटन (क्वेरी को निष्पादित करने के लिए) दबाएं।
परिणाम
निष्पादित करने पर, आपको निम्नलिखित परिणाम मिलेगा।
कई नोड्स लौटना
आप रिटर्न क्लॉज का उपयोग करके कई नोड्स भी लौटा सकते हैं।
वाक्य - विन्यास
वापसी क्लॉज का उपयोग करके कई नोड्स वापस करने के लिए सिंटैक्स है।
CREATE (Ind:Country {name: "India", result: "Winners"})
CREATE (CT2013:Tornament {name: "ICC Champions Trophy 2013"})
RETURN Ind, CT2013
उदाहरण
निम्नलिखित क्लॉज का उपयोग करके कई नोड्स को वापस करने के लिए एक नमूना Cypher क्वेरी है।
CREATE (Ind:Country {name: "India", result: "Winners"})
CREATE (CT2013:Tornament {name: "ICC Champions Trophy 2013"})
RETURN Ind, CT2013
उपरोक्त क्वेरी निष्पादित करने के लिए, निम्न चरणों का पालन करें -
Step 1- Neo4j डेस्कटॉप ऐप खोलें और Neo4j सर्वर शुरू करें। URL का उपयोग करके Neo4j का अंतर्निहित ब्राउज़र ऐप खोलेंhttp://localhost:7474/ जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।
Step 2 - डॉलर प्रॉम्प्ट में वांछित क्वेरी को कॉपी और पेस्ट करें और निम्न स्क्रीनशॉट में हाइलाइट किए गए प्ले बटन (क्वेरी को निष्पादित करने के लिए) दबाएं।
परिणाम
निष्पादित करने पर, आपको निम्नलिखित परिणाम मिलेगा। यहाँ आप देख सकते हैं कि Neo4j ने 2 नोड लौटाए हैं।
लौटते हुए रिश्ते
आप रिटर्न क्लॉज का उपयोग करके रिश्तों को भी लौटा सकते हैं।
वाक्य - विन्यास
RETURN क्लॉज का उपयोग करके रिश्तों को वापस करने का सिंटैक्स निम्नलिखित है।
CREATE (node1)-[Relationship:Relationship_type]->(node2)
RETURN Relationship
उदाहरण
निम्नलिखित एक नमूना साइफर क्वेरी है जो दो संबंध बनाता है और उन्हें वापस करता है।
CREATE (Ind)-[r1:WINNERS_OF {NRR:0.938 ,pts:6}]->(CT2013)
CREATE(Dhoni)-[r2:CAPTAIN_OF]->(Ind)
RETURN r1, r2
उपरोक्त क्वेरी निष्पादित करने के लिए, निम्न चरणों का पालन करें -
Step 1- Neo4j डेस्कटॉप ऐप खोलें और Neo4j सर्वर शुरू करें। URL का उपयोग करके Neo4j का अंतर्निहित ब्राउज़र ऐप खोलेंhttp://localhost:7474/ जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।
Step 2 - डॉलर प्रॉम्प्ट में वांछित क्वेरी को कॉपी और पेस्ट करें और निम्न स्क्रीनशॉट में हाइलाइट किए गए प्ले बटन (क्वेरी को निष्पादित करने के लिए) दबाएं।
परिणाम
निष्पादित करने पर, आपको निम्नलिखित परिणाम मिलेगा।
लौटने के गुण
आप RETURN क्लॉज का उपयोग करके भी गुण लौटा सकते हैं।
वाक्य - विन्यास
RETURN क्लॉज का उपयोग करके गुणों को वापस करने के लिए एक सिंटैक्स है।
Match (node:label {properties . . . . . . . . . . })
Return node.property
उदाहरण
एक नोड के गुणों को वापस करने के लिए एक नमूना Cypher क्वेरी है।
Match (Dhoni:player {name: "MahendraSingh Dhoni", YOB: 1981, POB: "Ranchi"})
Return Dhoni.name, Dhoni.POB
उपरोक्त क्वेरी निष्पादित करने के लिए, निम्न चरणों का पालन करें -
Step 1- Neo4j डेस्कटॉप ऐप खोलें और Neo4j सर्वर शुरू करें। URL का उपयोग करके Neo4j का अंतर्निहित ब्राउज़र ऐप खोलेंhttp://localhost:7474/ जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।
Step 2 - डॉलर प्रॉम्प्ट में वांछित क्वेरी को कॉपी और पेस्ट करें और निम्न स्क्रीनशॉट में हाइलाइट किए गए प्ले बटन (क्वेरी को निष्पादित करने के लिए) दबाएं।
परिणाम
निष्पादित करने पर, आपको निम्नलिखित परिणाम मिलेगा।
सभी तत्वों को लौटाना
आप Neo4j डेटाबेस में RETURN क्लॉज का उपयोग करके सभी तत्वों को वापस कर सकते हैं।
उदाहरण
डेटाबेस में सभी तत्वों को वापस करने के लिए एक उदाहरण Cypher Query है।
Match p = (n {name: "India", result: "Winners"})-[r]-(x)
RETURN *
उपरोक्त क्वेरी निष्पादित करने के लिए, निम्न चरणों का पालन करें -
Step 1- Neo4j डेस्कटॉप ऐप खोलें और Neo4j सर्वर शुरू करें। URL का उपयोग करके Neo4j का अंतर्निहित ब्राउज़र ऐप खोलेंhttp://localhost:7474/ जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।
Step 2 - डॉलर प्रॉम्प्ट में वांछित क्वेरी को कॉपी और पेस्ट करें और निम्न स्क्रीनशॉट में हाइलाइट किए गए प्ले बटन (क्वेरी को निष्पादित करने के लिए) दबाएं।
परिणाम
निष्पादित करने पर, आपको निम्नलिखित परिणाम मिलेगा।
एक कॉलम उपनाम के साथ एक चर लौटना
आप Neo4j में RETURN क्लॉज का उपयोग करके उपनाम के साथ एक विशेष कॉलम वापस कर सकते हैं।
उदाहरण
निम्नलिखित एक नमूना साइफर क्वेरी है जो स्तंभ POB को जन्म स्थान के रूप में लौटाता है।
Match (Dhoni:player {name: "MahendraSingh Dhoni", YOB: 1981, POB: "Ranchi"})
Return Dhoni.POB as Place Of Birth
उपरोक्त क्वेरी निष्पादित करने के लिए, निम्न चरणों का पालन करें -
Step 1- Neo4j डेस्कटॉप ऐप खोलें और Neo4j सर्वर शुरू करें। URL का उपयोग करके Neo4j का अंतर्निहित ब्राउज़र ऐप खोलेंhttp://localhost:7474/ जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।
Step 2 - डॉलर प्रॉम्प्ट में वांछित क्वेरी को कॉपी और पेस्ट करें और निम्न स्क्रीनशॉट में हाइलाइट किए गए प्ले बटन (क्वेरी को निष्पादित करने के लिए) दबाएं।
परिणाम
निष्पादित करने पर, आपको निम्नलिखित परिणाम मिलेगा।
आप ORDER BY खंड का उपयोग करके परिणाम डेटा की व्यवस्था कर सकते हैं।
वाक्य - विन्यास
इसके बाद ORDER BY क्लॉज का वाक्य विन्यास है।
MATCH (n)
RETURN n.property1, n.property2 . . . . . . . .
ORDER BY n.property
उदाहरण
उदाहरण के साथ आगे बढ़ने से पहले Neo4j डेटाबेस में 5 नोड बनाएं जैसा कि नीचे दिखाया गया है।
CREATE(Dhawan:player{name:"shikar Dhawan", YOB: 1985, runs:363, country: "India"})
CREATE(Jonathan:player{name:"Jonathan Trott", YOB:1981, runs:229, country:"South Africa"})
CREATE(Sangakkara:player{name:"Kumar Sangakkara", YOB:1977, runs:222, country:"Srilanka"})
CREATE(Rohit:player{name:"Rohit Sharma", YOB: 1987, runs:177, country:"India"})
CREATE(Virat:player{name:"Virat Kohli", YOB: 1988, runs:176, country:"India"})
निम्नलिखित एक नमूना साइफर क्वेरी है जो ORDERBY खण्ड का उपयोग करके खिलाड़ी द्वारा बनाए गए रनों के क्रम में उपरोक्त बनाए गए नोड्स को लौटाता है।
MATCH (n)
RETURN n.name, n.runs
ORDER BY n.runs
उपरोक्त क्वेरी निष्पादित करने के लिए, निम्न चरणों का पालन करें -
Step 1- Neo4j डेस्कटॉप ऐप खोलें और Neo4j सर्वर शुरू करें। URL का उपयोग करके Neo4j का अंतर्निहित ब्राउज़र ऐप खोलेंhttp://localhost:7474/ जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।
Step 2 - डॉलर प्रॉम्प्ट में वांछित क्वेरी को कॉपी और पेस्ट करें और निम्न स्क्रीनशॉट में हाइलाइट किए गए प्ले बटन (क्वेरी को निष्पादित करने के लिए) दबाएं।
परिणाम
निष्पादित करने पर, आपको निम्नलिखित परिणाम मिलेगा।
एकाधिक गुणों द्वारा आदेश नोड्स
आप कई गुणों का उपयोग करके नोड्स की व्यवस्था कर सकते हैं ORDEYBY खंड।
वाक्य - विन्यास
ORDERBY क्लॉज का उपयोग करके कई गुणों द्वारा नोड्स की व्यवस्था करने के लिए सिंटैक्स निम्नलिखित है।
MATCH (n)
RETURN n
ORDER BY n.age, n.name
उदाहरण
निम्नलिखित एक नमूना साइफर क्वेरी है जो इस अध्याय में पहले बनाए गए नोड्स की व्यवस्था करता है जो गुणों - रन और देश पर आधारित है।
MATCH (n)
RETURN n.name, n.runs, n.country
ORDER BY n.runs, n.country
उपरोक्त क्वेरी निष्पादित करने के लिए, निम्न चरणों का पालन करें -
Step 1- Neo4j डेस्कटॉप ऐप खोलें और Neo4j सर्वर शुरू करें। URL का उपयोग करके Neo4j का अंतर्निहित ब्राउज़र ऐप खोलेंhttp://localhost:7474/ जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।
Step 2 - डॉलर प्रॉम्प्ट में वांछित क्वेरी को कॉपी और पेस्ट करें और निम्न स्क्रीनशॉट में हाइलाइट किए गए प्ले बटन (क्वेरी को निष्पादित करने के लिए) दबाएं।
परिणाम
निष्पादित करने पर, आपको निम्नलिखित परिणाम मिलेगा।
अवरोही क्रम द्वारा नोड्स का आदेश देना
आप एक डेटाबेस में एक अवरोही क्रम में नोड्स की व्यवस्था कर सकते हैं ORDERBY खंड।
वाक्य - विन्यास
डेटाबेस में नोड्स को व्यवस्थित करने के लिए सिंटैक्स निम्नलिखित है।
MATCH (n)
RETURN n
ORDER BY n.name DESC
उदाहरण
निम्नलिखित एक नमूना साइपर क्वेरी है जो ORDERBY क्लॉज का उपयोग करके एक अवरोही क्रम में डेटाबेस में नोड्स की व्यवस्था करता है।
MATCH (n)
RETURN n.name, n.runs
ORDER BY n.runs DESC
उपरोक्त क्वेरी निष्पादित करने के लिए, निम्न चरणों का पालन करें -
Step 1- Neo4j डेस्कटॉप ऐप खोलें और Neo4j सर्वर शुरू करें। URL का उपयोग करके Neo4j का अंतर्निहित ब्राउज़र ऐप खोलेंhttp://localhost:7474/ जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।
Step 2 - डॉलर प्रॉम्प्ट में वांछित क्वेरी को कॉपी और पेस्ट करें और निम्न स्क्रीनशॉट में हाइलाइट किए गए प्ले बटन (क्वेरी को निष्पादित करने के लिए) दबाएं।
परिणाम
निष्पादित करने पर, आपको निम्नलिखित परिणाम मिलेगा।
limit क्लॉज का उपयोग आउटपुट में पंक्तियों की संख्या को सीमित करने के लिए किया जाता है।
वाक्य - विन्यास
निम्नलिखित सीमा खंड का सिंटैक्स है।
MATCH (n)
RETURN n
ORDER BY n.name
LIMIT 3
उदाहरण
उदाहरण के साथ आगे बढ़ने से पहले, नीचे दिखाए गए अनुसार Neo4j डेटाबेस में 5 नोड बनाएं।
CREATE(Dhawan:player{name:"shikar Dhawan", YOB: 1985, runs:363, country: "India"})
CREATE(Jonathan:player{name:"Jonathan Trott", YOB:1981, runs:229, country:"South Africa"})
CREATE(Sangakkara:player{name:"Kumar Sangakkara", YOB:1977, runs:222, country:"Srilanka"})
CREATE(Rohit:player{name:"Rohit Sharma", YOB: 1987, runs:177, country:"India"})
CREATE(Virat:player{name:"Virat Kohli", YOB: 1988, runs:176, country:"India"})
निम्नलिखित एक नमूना साइफर क्वेरी है जो ऊपर दिए गए नोड्स को एक अवरोही क्रम में लौटाता है और 3 के परिणाम में रिकॉर्ड को सीमित करता है।
MATCH (n)
RETURN n.name, n.runs
ORDER BY n.runs DESC
LIMIT 3
उपरोक्त क्वेरी निष्पादित करने के लिए, निम्न चरणों का पालन करें -
Step 1- Neo4j डेस्कटॉप ऐप खोलें और Neo4j सर्वर शुरू करें। URL का उपयोग करके Neo4j का अंतर्निहित ब्राउज़र ऐप खोलेंhttp://localhost:7474/ जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।
Step 2 - डॉलर प्रॉम्प्ट में वांछित क्वेरी को कॉपी और पेस्ट करें और निम्न स्क्रीनशॉट में हाइलाइट किए गए प्ले बटन (क्वेरी को निष्पादित करने के लिए) दबाएं।
परिणाम
निष्पादित करने पर, आपको निम्नलिखित परिणाम मिलेगा।
अभिव्यक्ति के साथ सीमा
तुम भी अभिव्यक्ति के साथ सीमा खंड का उपयोग कर सकते हैं।
उदाहरण
निम्नलिखित एक नमूना साइफर क्वेरी है जो एक अभिव्यक्ति का उपयोग करके रिकॉर्ड को सीमित करता है।
MATCH (n)
RETURN n.name, n.runs
ORDER BY n.runs DESC
LIMIT toInt(3 * rand())+ 1
उपरोक्त क्वेरी निष्पादित करने के लिए, निम्न चरणों का पालन करें -
Step 1- Neo4j डेस्कटॉप ऐप खोलें और Neo4j सर्वर शुरू करें। URL का उपयोग करके Neo4j का अंतर्निहित ब्राउज़र ऐप खोलेंhttp://localhost:7474/ जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।
Step 2 - डॉलर प्रॉम्प्ट में वांछित क्वेरी को कॉपी और पेस्ट करें और निम्न स्क्रीनशॉट में हाइलाइट किए गए प्ले बटन (क्वेरी को निष्पादित करने के लिए) दबाएं।
परिणाम
निष्पादित करने पर, आपको निम्नलिखित परिणाम मिलेगा।
SKIP क्लॉज का उपयोग आउटपुट में पंक्तियों को शुरू करने के लिए किस पंक्ति से परिभाषित करने के लिए किया जाता है।
उदाहरण
उदाहरण के साथ आगे बढ़ने से पहले, नीचे दिखाए गए अनुसार 5 नोड बनाएं।
CREATE(Dhawan:player{name:"shikar Dhawan", YOB: 1985, runs:363, country: "India"})
CREATE(Jonathan:player{name:"Jonathan Trott", YOB:1981, runs:229, country:"South Africa"})
CREATE(Sangakkara:player{name:"Kumar Sangakkara", YOB:1977, runs:222, country:"Srilanka"})
CREATE(Rohit:player{name:"Rohit Sharma", YOB: 1987, runs:177, country:"India"})
CREATE(Virat:player{name:"Virat Kohli", YOB: 1988, runs:176, country:"India"})
निम्नलिखित एक नमूना Cypher Query है जो डेटाबेस में सभी नोड्स को पहले 3 नोड्स को छोड़ देता है।
MATCH (n)
RETURN n.name, n.runs
ORDER BY n.runs DESC
SKIP 3
उपरोक्त क्वेरी निष्पादित करने के लिए, निम्न चरणों का पालन करें -
Step 1- Neo4j डेस्कटॉप ऐप खोलें और Neo4j सर्वर शुरू करें। URL का उपयोग करके Neo4j का अंतर्निहित ब्राउज़र ऐप खोलेंhttp://localhost:7474/ जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।
Step 2 - डॉलर प्रॉम्प्ट में वांछित क्वेरी को कॉपी और पेस्ट करें और निम्न स्क्रीनशॉट में हाइलाइट किए गए प्ले बटन (क्वेरी को निष्पादित करने के लिए) दबाएं।
परिणाम
निष्पादित करने पर, आपको निम्नलिखित परिणाम मिलेगा।
अभिव्यक्ति का उपयोग छोड़ें
आप एक अभिव्यक्ति का उपयोग करके परिणाम के रिकॉर्ड को छोड़ सकते हैं।
उदाहरण
निम्नलिखित एक नमूना Cypher क्वेरी है जो एक अभिव्यक्ति के साथ SKIP क्लॉज का उपयोग करता है।
MATCH (n)
RETURN n.name, n.runs
ORDER BY n.runs DESC
SKIP toInt (2*rand())+ 1
Step 1- Neo4j डेस्कटॉप ऐप खोलें और Neo4j सर्वर शुरू करें। URL का उपयोग करके Neo4j का अंतर्निहित ब्राउज़र ऐप खोलेंhttp://localhost:7474/ जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।
Step 2 - डॉलर प्रॉम्प्ट में वांछित क्वेरी को कॉपी और पेस्ट करें और निम्न स्क्रीनशॉट में हाइलाइट किए गए प्ले बटन (क्वेरी को निष्पादित करने के लिए) दबाएं।
परिणाम
निष्पादित करने पर, आपको निम्नलिखित परिणाम मिलेगा।
आप क्लॉज के उपयोग से क्वेरी आर्ट्स को एक साथ चेन कर सकते हैं।
वाक्य - विन्यास
निम्नलिखित विराम का सिंटैक्स है।
MATCH (n)
WITH n
ORDER BY n.property
RETURN collect(n.property)
उदाहरण
निम्नलिखित एक नमूना साइफर क्वेरी है जो विराम के उपयोग को दर्शाता है।
MATCH (n)
WITH n
ORDER BY n.name DESC LIMIT 3
RETURN collect(n.name)
उपरोक्त क्वेरी निष्पादित करने के लिए, निम्न चरणों का पालन करें -
Step 1- Neo4j डेस्कटॉप ऐप खोलें और Neo4j सर्वर शुरू करें। URL का उपयोग करके Neo4j का अंतर्निहित ब्राउज़र ऐप खोलेंhttp://localhost:7474/ जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।
Step 2 - डॉलर प्रॉम्प्ट में वांछित क्वेरी को कॉपी और पेस्ट करें और निम्न स्क्रीनशॉट में हाइलाइट किए गए प्ले बटन (क्वेरी को निष्पादित करने के लिए) दबाएं।
परिणाम
निष्पादित करने पर, आपको निम्नलिखित परिणाम मिलेगा।
पंक्तियों के अनुक्रम में एक सूची को खोलने के लिए खोलना खंड का उपयोग किया जाता है।
उदाहरण
निम्नलिखित एक नमूना Cypher क्वेरी है जो एक सूची को दिखाता है।
UNWIND [a, b, c, d] AS x
RETURN x
उपरोक्त क्वेरी निष्पादित करने के लिए, निम्न चरणों का पालन करें -
Step 1- Neo4j डेस्कटॉप ऐप खोलें और Neo4j सर्वर शुरू करें। URL का उपयोग करके Neo4j का अंतर्निहित ब्राउज़र ऐप खोलेंhttp://localhost:7474/ जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।
Step 2 - डॉलर प्रॉम्प्ट में वांछित क्वेरी को कॉपी और पेस्ट करें और निम्न स्क्रीनशॉट में हाइलाइट किए गए प्ले बटन (क्वेरी को निष्पादित करने के लिए) दबाएं।
परिणाम
निष्पादित करने पर, आपको निम्नलिखित परिणाम मिलेगा।
SQL की तरह, Neo4J CQL ने आवश्यक परिणाम प्राप्त करने के लिए CQL क्वेरी में उनका उपयोग करने के लिए स्ट्रिंग फ़ंक्शन का एक सेट प्रदान किया है।
यहां, हम कुछ महत्वपूर्ण और अक्सर उपयोग किए जाने वाले कार्यों पर चर्चा करने जा रहे हैं।
स्ट्रिंग फ़ंक्शंस सूची
Neo4j में प्रमुख स्ट्रिंग कार्यों की सूची निम्नलिखित है।
अनु क्रमांक | समारोह विवरण |
---|---|
1 | ऊपरी इसका उपयोग सभी पत्रों को ऊपरी मामलों के अक्षरों में बदलने के लिए किया जाता है। |
2 | कम इसका उपयोग सभी पत्रों को निचले मामलों के अक्षरों में बदलने के लिए किया जाता है। |
3 | सबस्ट्रिंग इसका उपयोग किसी दिए गए स्ट्रिंग के प्रतिस्थापन प्राप्त करने के लिए किया जाता है। |
4 | Replace इसका उपयोग स्ट्रिंग के दिए गए विकल्प के साथ एक प्रतिस्थापन को बदलने के लिए किया जाता है। |
SQL की तरह, Neo4j CQL ने RETURN क्लॉज में उपयोग करने के लिए कुछ एकत्रीकरण कार्य प्रदान किए हैं। यह SQL में GROUP BY क्लॉज के समान है।
हम इस RETURN + एकत्रीकरण कार्यों का उपयोग MATCH कमांड में नोड्स के समूह पर काम करने के लिए कर सकते हैं और कुछ एकत्रित मूल्य वापस कर सकते हैं।
कृषि कार्य सूची
निम्नलिखित Neo4j में एकत्रीकरण कार्यों की सूची है।
अनु क्रमांक | समारोह विवरण |
---|---|
1 | गिनती यह MATCH कमांड द्वारा दी गई पंक्तियों की संख्या लौटाता है। |
2 | मैक्स यह MATCH कमांड द्वारा लौटी पंक्तियों के एक सेट से अधिकतम मूल्य देता है। |
3 | मिनट यह MATCH कमांड द्वारा लौटी पंक्तियों के एक सेट से न्यूनतम मान लौटाता है। |
4 | योग यह MATCH कमांड द्वारा लौटाए गए सभी पंक्तियों का योग मान लौटाता है। |
5 | औसत यह MATCH कमांड द्वारा दी गई सभी पंक्तियों का औसत मान लौटाता है। |
वास्तविक समय के अनुप्रयोगों में, हमें अपने एप्लिकेशन डेटाबेस का नियमित रूप से बैकअप लेना चाहिए, ताकि हम किसी भी विफलता बिंदु पर कुछ काम करने की स्थिति को बहाल कर सकें।
यह नियम RDBMS और NoSQL डेटाबेस दोनों के लिए लागू है।
इस खंड में, हम DBA के दो महत्वपूर्ण कार्यों के बारे में चर्चा करने जा रहे हैं।
- Neo4j डेटाबेस का बैकअप कैसे लें।
- Neo4j डेटाबेस को एक विशिष्ट बैकअप पर कैसे पुनर्स्थापित करें।
Note- ये चरण केवल विंडोज ऑपरेटिंग सिस्टम पर लागू होते हैं। हमें अन्य ऑपरेटिंग सिस्टम में समान चरणों को करने के लिए इसी तरह के कमांड का उपयोग करना चाहिए।
Neo4j डेटाबेस बैकअप
Step 1 - निम्न पथ का उपयोग करके "Neo4j समुदाय" पर क्लिक करें -
Windows "प्रारंभ" बटन → "सभी कार्यक्रम" → "Neo4j समुदाय" → "Neo4j समुदाय"
डिफ़ॉल्ट रूप से, यह चयन करता है c:\Users\[username]\Documents\Neo4j\default.graphdb. हालाँकि अगर हम चाहें, तो हम एक अलग निर्देशिका में पथ बदल सकते हैं।
Step 2 - यहां हमने अपने Neo4j डाटाबेस फोल्डर में बदलाव किया है।
C: \ Ne04j2.0db
Step 3 - "प्रारंभ" बटन पर क्लिक करें।
एक बार सर्वर शुरू होने के बाद, हम देख सकते हैं कि हमारी Neo4j डेटाबेस फाइलें एक निर्दिष्ट निर्देशिका में उत्पन्न हुई हैं।
डेटाबेस बैकअप लेने से पहले, हमें सबसे पहले और सबसे महत्वपूर्ण चीज जो करनी चाहिए वह है Neo4j डेटाबेस सर्वर।
Step 4 - सर्वर बंद करने के लिए "स्टॉप" बटन पर क्लिक करें।
Neo4j डेटाबेस फाइलें C: \ Ne04j2.0db पर उपलब्ध हैं
Step 5 - कमांड प्रॉम्प्ट खोलें।
Step 6 - C: \ Neo4j पर एक फ़ोल्डर "Neo4jDbBackup-01" बनाएं (यह आपके फाइल सिस्टम में कोई भी स्थान हो सकता है)।
mkdir C:\Neo4j\Neo4jDbBackup-01
यह निर्दिष्ट फ़ाइल सिस्टम स्थान "C: \ Neojjb" पर एक नया फ़ोल्डर "Neo4jDbBackup-01" बनाता है
Step 7 - निम्न कमांड टाइप करें और एंटर की दबाएं।
copy C:\Ne04j2.0db C:\Neo4j\Neo4jDbBackup-01
इसका अर्थ है कि हमारी फ़ाइलें आवश्यक गंतव्य फ़ोल्डर में कॉपी की जाती हैं। उस फ़ोल्डर तक पहुँचें और देखें कि फ़ोल्डर में हमारी डेटाबेस फाइलें हैं।
Step 8 - हमारे डेटाबेस फ़ोल्डर को ज़िप करने के लिए WinZip, 7 Zip, या WinRAR जैसे किसी भी विंडोज कंप्रेशन / डीकम्प्रेशन टूल का उपयोग करें।
Step 9- अब हमारी Neo4jDbBackup-01.zip फ़ाइल बन गई है। यदि आपके फ़ाइल सिस्टम में कोई मेमोरी बाधा है, तो "C: \ Neo4j \" पर "Neo4jDbBackup-01" फ़ोल्डर को हटा दें
Neo4j डेटाबेस पुनर्स्थापित करें
Step 1- डेटाबेस सर्वर को शटडाउन करें। कृपया सर्वर को बंद करने के लिए पिछले चरणों का संदर्भ लें।
Step 2 - वर्तमान डेटाबेस फ़ोल्डर खाली करें।
Step 3 - हमारे बैकअप फ़ोल्डर को अनज़िप करने के लिए WinZip, 7 Zip, या WinRar जैसे किसी भी विंडोज कम्प्रेशन / डीकम्प्रेशन टूल का उपयोग करें।
Step 4 - कमांड प्रॉम्प्ट खोलें और निम्न कमांड निष्पादित करें।
Copy C:\Neo4j\Neo4jDbBackup-01 C:\Ne04j2.0db
अब हम यह देख सकते हैं कि हमारे डेटाबेस फोल्डर में बैकअप फाइल काम कर रही है
Step 5 - "प्रारंभ" बटन पर क्लिक करके सर्वर शुरू करें।
Step 6 - सत्यापित करने के लिए कि हमने अपने डेटाबेस को ठीक से पुनर्स्थापित किया है, कुछ MATCH + RETURN कमांड निष्पादित करें।
Neo4j SQL अनुप्रयोग के प्रदर्शन को बेहतर बनाने के लिए नोड या संबंध गुणों पर अनुक्रमित का समर्थन करता है। हम सभी नोड्स के लिए गुणों पर अनुक्रमित बना सकते हैं, जिनमें समान लेबल नाम है।
हम CQL कमांड के निष्पादन को बेहतर बनाने के लिए MATCH या WHERE या IN ऑपरेटर पर इन अनुक्रमित स्तंभों का उपयोग कर सकते हैं।
इस अध्याय में, हम चर्चा करेंगे कि कैसे -
- एक इंडेक्स बनाएं
- एक सूचकांक हटाएं
एक सूचकांक बनाना
Neo4j CQL नोड या रिलेशनशिप प्रॉपर्टीज पर इंडेक्स बनाने के लिए "CREATE INDEX" कमांड प्रदान करता है।
वाक्य - विन्यास
Neo4j में एक इंडेक्स बनाने के लिए सिंटैक्स निम्नलिखित है।
CREATE INDEX ON:label (node)
उदाहरण
उदाहरण के साथ आगे बढ़ने से पहले, नीचे दिखाए गए अनुसार एक नोड धवन बनाएं।
CREATE (Dhawan:player{name: "shikar Dhawan", YOB: 1995, POB: "Delhi"})
Neo4j में नोड धवन पर एक इंडेक्स बनाने के लिए एक नमूना Cypher क्वेरी है।
CREATE INDEX ON:player(Dhawan)
उपरोक्त क्वेरी निष्पादित करने के लिए, निम्न चरणों का पालन करें -
Step 1- Neo4j डेस्कटॉप ऐप खोलें और Neo4j सर्वर शुरू करें। URL का उपयोग करके Neo4j का अंतर्निहित ब्राउज़र ऐप खोलेंhttp://localhost:7474/ जैसा की नीचे दिखाया गया।
Step 2 - डॉलर प्रॉम्प्ट में वांछित क्वेरी को कॉपी और पेस्ट करें और निम्न स्क्रीनशॉट में हाइलाइट किए गए प्ले बटन (क्वेरी को निष्पादित करने के लिए) दबाएं।
परिणाम
निष्पादित करने पर, आपको निम्नलिखित परिणाम मिलेगा।
एक सूचकांक हटाना
Neo4j CQL एक नोड या रिलेशनशिप प्रॉपर्टी के मौजूदा इंडेक्स को छोड़ने के लिए "DROP INDEX" कमांड प्रदान करता है।
वाक्य - विन्यास
Neo4j में एक इंडेक्स बनाने के लिए सिंटैक्स निम्नलिखित है।
DROP INDEX ON:label(node)
उदाहरण
Neo4j में "धवन" नाम के नोड पर एक इंडेक्स बनाने के लिए एक नमूना साइपर क्वेरी का अनुसरण किया गया है।
DROP INDEX ON:player(Dhawan)
उपरोक्त क्वेरी निष्पादित करने के लिए, निम्न चरणों का पालन करें -
Step 1- Neo4j डेस्कटॉप ऐप खोलें और Neo4j सर्वर शुरू करें। URL का उपयोग करके Neo4j का अंतर्निहित ब्राउज़र ऐप खोलेंhttp://localhost:7474/ जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।
Step 2 - डॉलर प्रॉम्प्ट में वांछित क्वेरी को कॉपी और पेस्ट करें और निम्न स्क्रीनशॉट में हाइलाइट किए गए प्ले बटन (क्वेरी को निष्पादित करने के लिए) दबाएं।
परिणाम
निष्पादित करने पर, आपको निम्नलिखित परिणाम मिलेगा।
Neo4j डेटाबेस में, CQL क्रिएट कमांड हमेशा एक नया नोड या संबंध बनाता है जिसका अर्थ है कि भले ही आप समान मानों का उपयोग करते हैं, लेकिन यह एक नई पंक्ति सम्मिलित करता है। कुछ नोड्स या रिश्तों के लिए हमारे आवेदन की आवश्यकताओं के अनुसार, हमें इस दोहराव से बचना होगा। इसके लिए, हमें एक नोड या संबंध के एक या अधिक गुणों पर एक नियम बनाने के लिए कुछ डेटाबेस बाधाओं का उपयोग करना चाहिए।
SQL की तरह Neo4j डेटाबेस भी नोड या रिलेशनशिप संपत्तियों पर UNIQUE की कमी का समर्थन करता है। UNIQUE बाधा का उपयोग डुप्लिकेट रिकॉर्ड से बचने और डेटा अखंडता नियम को लागू करने के लिए किया जाता है।
UNIQUE बाधा बनाएँ
Neo4j CQL नोड या रिलेशनशिप प्रॉपर्टी पर अद्वितीय अवरोध बनाने के लिए "CREATE CONSTRAINT" कमांड प्रदान करता है।
वाक्य - विन्यास
Neo4j में एक UNIQUE बाधा बनाने के लिए सिंटैक्स निम्नलिखित है।
MATCH (root {name: "Dhawan"})
CREATE UNIQUE (root)-[:LOVES]-(someone)
RETURN someone
उदाहरण
उदाहरण के साथ आगे बढ़ने से पहले, नीचे दिखाए गए अनुसार 4 नोड बनाएं।
CREATE(Dhawan:player{id:001, name: "shikar Dhawan", YOB: 1995, POB: "Delhi"})
CREATE(Jonathan:player {id:002, name: "Jonathan Trott", YOB: 1981, POB: "CapeTown"})
CREATE(Sangakkara:player {id:003, name: "Kumar Sangakkara", YOB: 1977, POB: "Matale"})
CREATE(Rohit:player {id:004, name: "Rohit Sharma", YOB: 1987, POB: "Nagpur"})
CREATE(Virat:player {id:005, name: "Virat Kohli", YOB: 1988, POB: "Delhi"})
Neo4j का उपयोग करके संपत्ति आईडी पर एक UNIQUE बाधा बनाने के लिए एक नमूना Cypher क्वेरी है।
CREATE CONSTRAINT ON (n:player) ASSERT n.id IS UNIQUE
उपरोक्त क्वेरी निष्पादित करने के लिए, निम्न चरणों का पालन करें -
Step 1- Neo4j डेस्कटॉप ऐप खोलें और Neo4j सर्वर शुरू करें। URL का उपयोग करके Neo4j का अंतर्निहित ब्राउज़र ऐप खोलेंhttp://localhost:7474/ जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।
Step 2 - डॉलर प्रॉम्प्ट में वांछित क्वेरी को कॉपी और पेस्ट करें और निम्न स्क्रीनशॉट में हाइलाइट किए गए प्ले बटन (क्वेरी को निष्पादित करने के लिए) दबाएं।
परिणाम
निष्पादित करने पर, आपको निम्नलिखित परिणाम मिलेगा।
सत्यापन
अब, निरर्थक आईडी मान के साथ एक और नोड जोड़ने का प्रयास करें। यहां, हम आईडी के साथ एक नोड बनाने की कोशिश कर रहे हैं002।
CREATE (Jadeja:player {id:002, name: "Ravindra Jadeja", YOB: 1988, POB: "NavagamGhed"})
यदि आप इस क्वेरी को निष्पादित करते हैं, तो आपको निम्न स्क्रीनशॉट में दिखाए अनुसार एक त्रुटि संदेश मिलेगा।
हमने पहले ही पिछले अध्याय में उदाहरणों के साथ UNIQUE बाधा संचालन बनाने पर चर्चा की है। इस अध्याय में, हम उदाहरण के साथ UNIQUE बाधा संचालन को छोड़ने पर चर्चा करेंगे।
Neo4j CQL एक नोड या रिलेशनशिप प्रॉपर्टी से मौजूदा यूनीक कंस्ट्रक्शन को हटाने के लिए "DROP CONSTRAINT" कमांड प्रदान करता है।
वाक्य - विन्यास
Neo4j में एक UNIQUE बाधा को छोड़ने का सिंटैक्स निम्नलिखित है।
DROP CONSTRAINT ON (node:label)
ASSERT node.id IS UNIQUE
उदाहरण
संपत्ति पर UNIQUE बाधा को हटाने के लिए एक नमूना Cypher क्वेरी है id।
DROP CONSTRAINT ON (n:player)
ASSERT n.id IS UNIQUE
उपरोक्त क्वेरी निष्पादित करने के लिए, निम्न चरणों का पालन करें -
Step 1- Neo4j डेस्कटॉप ऐप खोलें और Neo4j सर्वर शुरू करें। URL का उपयोग करके Neo4j का अंतर्निहित ब्राउज़र ऐप खोलेंhttp://localhost:7474/ जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।
Step 2 - डॉलर प्रॉम्प्ट में वांछित क्वेरी को कॉपी और पेस्ट करें और निम्न स्क्रीनशॉट में हाइलाइट किए गए प्ले बटन (क्वेरी को निष्पादित करने के लिए) दबाएं।
परिणाम
निष्पादित करने पर, आपको निम्नलिखित परिणाम मिलेगा।