OrientDB - प्रदर्शन रिकॉर्ड्स

RDBMS के समान, OrientDB डेटाबेस से रिकॉर्ड को पुनः प्राप्त करने के लिए विभिन्न प्रकार के SQL प्रश्नों का समर्थन करता है। अभिलेखों को पुनर्प्राप्त करते समय हमारे पास अलग-अलग विविधताएँ या चुनिंदा कथन के साथ प्रश्नों के विकल्प होते हैं।

निम्न कथन SELECT कमांड का मूल सिंटैक्स है।

SELECT [ <Projections> ] [ FROM <Target> [ LET <Assignment>* ] ] 
   [ WHERE <Condition>* ] 
   [ GROUP BY <Field>* ] 
   [ ORDER BY <Fields>* [ ASC|DESC ] * ] 
   [ UNWIND <Field>* ] 
   [ SKIP <SkipRecords> ] 
   [ LIMIT <MaxRecords> ] 
   [ FETCHPLAN <FetchPlan> ] 
   [ TIMEOUT <Timeout> [ <STRATEGY> ] ]
   [ LOCK default|record ] 
   [ PARALLEL ] 
   [ NOCACHE ]

उपरोक्त सिंटैक्स में विकल्पों के बारे में विवरण निम्नलिखित हैं।

<Projections> - परिणाम रिकॉर्ड सेट के रूप में क्वेरी से निकाले जाने वाले डेटा को इंगित करता है।

FROM- क्वेरी के लिए ऑब्जेक्ट इंगित करता है। यह एक क्लास, क्लस्टर, सिंगल रिकॉर्ड आईडी, रिकॉर्ड आईडी का सेट हो सकता है। आप इन सभी वस्तुओं को लक्ष्य के रूप में निर्दिष्ट कर सकते हैं।

WHERE - परिणाम सेट को फ़िल्टर करने के लिए स्थिति निर्दिष्ट करता है।

LET - संदर्भ चर इंगित करता है जो अनुमानों, शर्तों या उप प्रश्नों में उपयोग किया जाता है।

GROUP BY - रिकॉर्ड को समूहीकृत करने के लिए फ़ील्ड को इंगित करता है।

ORDER BY - आदेश में एक रिकॉर्ड की व्यवस्था करने के लिए दायर की गई है।

UNWIND - उस क्षेत्र को नामित करता है जिस पर अभिलेखों के संग्रह को खोलना है।

SKIP - रिजल्ट-सेट की शुरुआत से जितने रिकॉर्ड आप छोड़ना चाहते हैं, उसे परिभाषित करता है।

LIMIT - परिणाम-सेट में रिकॉर्ड की अधिकतम संख्या दर्शाता है।

FETCHPLAN - रणनीति को परिभाषित करता है कि आप परिणाम कैसे प्राप्त करना चाहते हैं।

TIMEOUT - क्वेरी के लिए मिलीसेकंड में अधिकतम समय को परिभाषित करता है।

LOCK- लॉकिंग रणनीति को परिभाषित करता है। DEFAULT और RECORD उपलब्ध लॉक स्ट्रेटेजी हैं।

PARALLEL - 'एक्स' समवर्ती धागे के खिलाफ क्वेरी निष्पादित करता है।

NOCACHE - परिभाषित करता है कि आप कैश का उपयोग करना चाहते हैं या नहीं।

उदाहरण

आइए पिछले अध्याय में बनाई गई निम्नलिखित ग्राहक तालिका पर विचार करें।

अनु क्रमांक।नामउम्र
1सतीश25
2कृष्णा26
3किरण29
4जावेद21
5राजा29

ग्राहक तालिका से डेटा रिकॉर्ड को पुनः प्राप्त करने के लिए अलग-अलग चयन करें।

Method 1 - आप ग्राहक तालिका से सभी रिकॉर्ड का चयन करने के लिए निम्नलिखित क्वेरी का उपयोग कर सकते हैं।

orientdb {db = demo}> SELECT FROM Customer

यदि उपरोक्त क्वेरी को सफलतापूर्वक निष्पादित किया जाता है, तो आपको निम्न आउटपुट मिलेगा।

----+-----+--------+----+-------+---- 
#   |@RID |@CLASS  |id  |name   |age  
----+-----+--------+----+-------+---- 
0   |#11:0|Customer|1   |satish |25   
1   |#11:1|Customer|2   |krishna|26   
2   |#11:2|Customer|3   |kiran  |29 
3   |#11:3|Customer|4   |javeed |21 
4   |#11:4|Customer|5   |raja   |29   
----+-----+--------+----+-------+----

Method 2 - उन सभी रिकॉर्डों का चयन करें जिनका नाम अक्षर से शुरू होता है 'k'।

orientdb {db = demo}> SELECT FROM Customer WHERE name LIKE 'k%'

या आप उपरोक्त उदाहरण के लिए निम्नलिखित क्वेरी का उपयोग कर सकते हैं।

orientdb {db = demo}> SELECT FROM Customer WHERE name.left(1) = 'k'

यदि उपरोक्त क्वेरी को सफलतापूर्वक निष्पादित किया जाता है, तो आपको निम्न आउटपुट मिलेगा।

----+-----+--------+----+-------+---- 
#   |@RID |@CLASS  |id  |name   |age  
----+-----+--------+----+-------+---- 
0   |#11:1|Customer|2   |krishna|26   
1   |#11:2|Customer|3   |kiran  |29 
----+-----+--------+----+-------+----

Method 3 - अपरकेस अक्षरों में नाम के साथ ग्राहक तालिका से आईडी, नाम रिकॉर्ड का चयन करें।

orientdb {db = demo}> SELECT id, name.toUpperCase() FROM Customer

यदि उपरोक्त क्वेरी को सफलतापूर्वक निष्पादित किया जाता है, तो आपको निम्न आउटपुट मिलेगा।

----+--------+----+------- 
#   |@CLASS  |id  |name     
----+--------+----+------- 
0   |null    |1   |SATISH   
1   |null    |2   |KRISHNA  
2   |null    |3   |KIRAN   
3   |null    |4   |JAVEED  
4   |null    |5   |RAJA      
----+--------+----+-------

Method 4 - ग्राहक तालिका से सभी रिकॉर्ड का चयन करें जहां उम्र 25 से 29 की सीमा में है।

orientdb {db = demo}> SELECT FROM Customer WHERE age in [25,29]

यदि उपरोक्त क्वेरी को सफलतापूर्वक निष्पादित किया जाता है, तो आपको निम्न आउटपुट मिलेगा।

----+-----+--------+----+-------+---- 
#   |@RID |@CLASS  |id  |name   |age  
----+-----+--------+----+-------+---- 
0   |#11:0|Customer|1   |satish |25   
1   |#11:2|Customer|3   |kiran  |29 
2   |#11:4|Customer|5   |raja   |29   
----+-----+--------+----+-------+----

Method 5 - ग्राहक तालिका से सभी रिकॉर्ड का चयन करें जहां किसी भी क्षेत्र में 'श' शब्द है।

orientdb {db = demo}> SELECT FROM Customer WHERE ANY() LIKE '%sh%'

यदि उपरोक्त क्वेरी को सफलतापूर्वक निष्पादित किया जाता है, तो आपको निम्न आउटपुट मिलेगा।

----+-----+--------+----+-------+---- 
#   |@RID |@CLASS  |id  |name   |age  
----+-----+--------+----+-------+---- 
0   |#11:0|Customer|1   |satish |25   
1   |#11:1|Customer|2   |krishna|26   
----+-----+--------+----+-------+----

Method 6 - ग्राहक तालिका से सभी रिकॉर्ड का चयन करें, क्रम में उम्र के अनुसार क्रम से।

orientdb {db = demo}> SELECT FROM Customer ORDER BY age DESC

यदि उपरोक्त क्वेरी को सफलतापूर्वक निष्पादित किया जाता है, तो आपको निम्न आउटपुट मिलेगा।

----+-----+--------+----+-------+---- 
#   |@RID |@CLASS  |id  |name   |age  
----+-----+--------+----+-------+---- 
0   |#11:2|Customer|3   |kiran  |29 
1   |#11:4|Customer|5   |raja   |29   
2   |#11:1|Customer|2   |krishna|26   
3   |#11:0|Customer|1   |satish |25   
4   |#11:3|Customer|4   |javeed |21 
----+-----+--------+----+-------+----