ओरिएंटबीडी - त्वरित गाइड

OrientDB एक ओपन सोर्स NoSQL डाटाबेस मैनेजमेंट सिस्टम है। NoSQL Databaseएनओ-रिलेशन या एनओएन-रिलेशनल डेटा को संग्रहीत करने और पुनर्प्राप्त करने के लिए एक तंत्र प्रदान करता है जो कि सारणीबद्ध डेटा जैसे दस्तावेज़ डेटा या ग्राफ़ डेटा के अलावा अन्य डेटा को संदर्भित करता है। NoSQL डेटाबेस बिग डेटा और वास्तविक समय वेब अनुप्रयोगों में तेजी से उपयोग किया जाता है। NoSQL सिस्टम को कभी-कभी जोर देने के लिए "Not Not SQL" भी कहा जाता है ताकि वे SQL जैसी क्वेरी भाषाओं का समर्थन कर सकें।

OrientDB भी NoSQL परिवार से संबंधित है। OrientDB एक दूसरी पीढ़ी का वितरित डेटाबेस है जिसमें अपाचे 2 लाइसेंस के खुले स्रोत के साथ एक उत्पाद में दस्तावेजों के लचीलेपन के साथ है। बाजार में ओरिएंटडीबी से पहले कई NoSQL डेटाबेस थे, उनमें से एक MongoDB है।

MongoDB बनाम ओरिएंटडीबी

MongoDB और OrientDB में कई सामान्य विशेषताएं हैं लेकिन इंजन मौलिक रूप से अलग हैं। MongoDB शुद्ध दस्तावेज़ डेटाबेस है और OrientDB ग्राफ़ इंजन के साथ एक हाइब्रिड दस्तावेज़ है।

विशेषताएं MongoDB OrientDB
Relationships संस्थाओं के बीच संबंध बनाने के लिए RDBMS JOINS का उपयोग करता है। इसकी उच्च रनटाइम लागत होती है और जब डेटाबेस स्केल बढ़ता है तो यह पैमाने पर नहीं होता है। एम्बेड और संबंधित डेटाबेस जैसे दस्तावेजों को जोड़ता है। यह ग्राफ डेटाबेस दुनिया से लिए गए प्रत्यक्ष, सुपर-फास्ट लिंक का उपयोग करता है।
Fetch Plan महंगा ऑपरेशन शामिल हैं। आसानी से परस्पर दस्तावेजों के साथ पूरा ग्राफ लौटाता है।
Transactions ACID लेनदेन का समर्थन नहीं करता है, लेकिन यह परमाणु संचालन का समर्थन करता है। ACID लेनदेन और परमाणु संचालन का समर्थन करता है।
Query language JSON पर आधारित अपनी भाषा है। क्वेरी भाषा SQL पर बनाई गई है।
Indexes सभी अनुक्रमितों के लिए बी-ट्री एल्गोरिथ्म का उपयोग करता है। तीन अलग-अलग इंडेक्सिंग एल्गोरिदम का समर्थन करता है ताकि उपयोगकर्ता सर्वश्रेष्ठ प्रदर्शन प्राप्त कर सके।
Storage engine मेमोरी मैपिंग तकनीक का उपयोग करता है। भंडारण इंजन नाम LOCAL और PLOCAL का उपयोग करता है।

OrientDB पहला मल्टी-मॉडल ओपन सोर्स NoSQL DBMS है जो ग्राफ़िक्स की शक्ति और दस्तावेजों के लचीलेपन को एक स्केलेबल हाई-परफॉर्मेंस ऑपरेशनल डेटाबेस में लाता है।

OrientDB स्थापना फ़ाइल दो संस्करणों में उपलब्ध है -

  • Community Edition - ओरिएंटडीबी सामुदायिक संस्करण अपाचे द्वारा एक खुले स्रोत के रूप में 0.2 लाइसेंस के तहत जारी किया गया है

  • Enterprise Edition- ओरिएंटबीडी एंटरप्राइज संस्करण एक मालिकाना सॉफ्टवेयर के रूप में जारी किया गया है, जो सामुदायिक संस्करण पर बनाया गया है। यह सामुदायिक संस्करण के विस्तार के रूप में कार्य करता है।

यह अध्याय ओरिएंटबीडी समुदाय संस्करण की स्थापना प्रक्रिया को बताता है क्योंकि यह खुला स्रोत है।

आवश्यक शर्तें

दोनों समुदाय और एंटरप्राइज़ संस्करण किसी भी ऑपरेटिंग सिस्टम पर चल सकते हैं जो जावा वर्चुअल मशीन (JVM) को लागू करता है। OrientDB को 1.7 या बाद के संस्करण के साथ जावा की आवश्यकता होती है।

अपने सिस्टम में OrientDB डाउनलोड और इंस्टॉल करने के लिए निम्न चरणों का उपयोग करें।

चरण 1 - डाउनलोड करें OrientDB बाइनरी सेटअप फ़ाइल

ओरिएंटबैंक आपके सिस्टम पर डेटाबेस को स्थापित करने के लिए अंतर्निहित सेटअप फ़ाइल के साथ आता है। यह अलग-अलग ऑपरेटिंग सिस्टम के लिए अलग-पूर्व संकलित बाइनरी पैकेज (टैरर्ड या ज़िप्ड पैकेज) प्रदान करता है। आप OrientDB डाउनलोड लिंक से OrientDB फाइलें डाउनलोड कर सकते हैं ।

निम्न स्क्रीनशॉट ओरिएंटडीबी के डाउनलोड पृष्ठ को दर्शाता है। आप उपयुक्त ऑपरेटिंग सिस्टम आइकन पर क्लिक करके ज़िपित या टैरर्ड फ़ाइल डाउनलोड कर सकते हैं।

डाउनलोड करने पर, आपको अपने में बाइनरी पैकेज मिलेगा Downloads फ़ोल्डर।

चरण 2 - ओरिएंटबीडी निकालें और स्थापित करें

निम्नलिखित विभिन्न ऑपरेटिंग सिस्टम के लिए ओरिएंटबीडी निकालने और स्थापित करने की प्रक्रिया है।

लिनक्स में

डाउनलोड करने के बाद आपको मिलेगा orientdb-community-2.1.9.tar.gz अपने में फाइल करें Downloadsफ़ोल्डर। टैरर्ड फ़ाइल को निकालने के लिए आप निम्न कमांड का उपयोग कर सकते हैं।

$ tar –zxvf orientdb-community-2.1.9.tar.gz

आप सभी OrientDB लाइब्रेरी फ़ाइलों को स्थानांतरित करने के लिए निम्न कमांड का उपयोग कर सकते हैं orientdbcommunity-2.1.9 to /opt/orientdb/निर्देशिका। यहां हम सुपर यूजर कमांड (sudo) का उपयोग कर रहे हैं इसलिए आपको निम्न कमांड को निष्पादित करने के लिए सुपर यूजर पासवर्ड प्रदान करना होगा।

$ sudo mv orientdb-community-2.1.9 /opt/orientdb

आप रजिस्टर करने के लिए निम्न कमांड का उपयोग कर सकते हैं orientdb कमांड और ओरिएंट सर्वर।

$ export ORIENTDB_HoME = /opt/orientdb $ export PATH = $PATH:$ORIENTDB_HOME/bin

विंडोज में

  • डाउनलोड करने के बाद आपको मिलेगा orientdb-community-2.1.9.zip अपने में फाइल करें Downloadsफ़ोल्डर। ज़िप एक्सट्रैक्टर का उपयोग करके ज़िप फ़ाइल को निकालें।

  • निकाले गए फ़ोल्डर को अंदर ले जाएं C:\ निर्देशिका।

  • दिए गए मानों के साथ दो पर्यावरण चर ORIENTDB_HOME और PATH चर बनाएं।

ORIENT_HOME = C:\orientdb-community-2.1.9 
PATH = C:\orientdb-community-2.1.9\bin

चरण 3 - ओरिएंटबीडी सर्वर को सेवा के रूप में कॉन्फ़िगर करना

उपरोक्त चरणों का पालन करके आप ओरिएंटबीडी के डेस्कटॉप संस्करण का उपयोग कर सकते हैं। आप निम्न चरणों का उपयोग करके ओरिएंटबीडी डेटाबेस सर्वर को एक सेवा के रूप में शुरू कर सकते हैं। प्रक्रिया अलग है, आपके ऑपरेटिंग सिस्टम पर निर्भर करती है।

लिनक्स में

OrientDB एक स्क्रिप्ट फ़ाइल प्रदान करता है जिसका नाम है orientdb.shएक डेमन के रूप में डेटाबेस को चलाने के लिए। आप इसे अपनी ओरिएंटडीबी स्थापना निर्देशिका के बिन / निर्देशिका में पा सकते हैं जो $ ORIENTDB_HOME / bin / Oridb.sh है।

स्क्रिप्ट फ़ाइल को चलाने से पहले, आपको संपादित करना होगा orientdb.shदो चर को परिभाषित करने के लिए फ़ाइल। एक हैORIENTDB_DIR जो स्थापना निर्देशिका के लिए मार्ग को परिभाषित करता है (/opt/orientdb) और दूसरा है ORIENTDB_USER जो आप के लिए OrientDB चलाना चाहते उपयोगकर्ता नाम को परिभाषित करता है।

ORIENTDB_DIR = "/opt/orientdb" 
ORIENTDB_USER = "<username you want to run OrientDB>"

कॉपी करने के लिए निम्न कमांड का उपयोग करें orientdb.sh में दर्ज करें /etc/init.d/स्क्रिप्ट को आरंभ करने और चलाने के लिए निर्देशिका। यहां हम सुपर यूजर कमांड (sudo) का उपयोग कर रहे हैं इसलिए आपको निम्न कमांड को निष्पादित करने के लिए सुपर यूजर पासवर्ड प्रदान करना होगा।

$ sudo cp $ORIENTDB_HOME/bin/orientdb.sh /etc/init.d/orientdb

OrientDB स्थापना निर्देशिका से कंसोल.श फ़ाइल की प्रतिलिपि बनाने के लिए निम्न आदेश का उपयोग करें $ORIENTDB_HOME/bin सिस्टम बिन निर्देशिका के लिए है /usr/bin ओरिएंट डीबी के कंसोल तक पहुँचने के लिए।

$ sudo cp $ ORIENTDB_HOME/bin/console.sh /usr/bin/orientdb

ORIENTDB डेटाबेस सर्वर को सेवा के रूप में शुरू करने के लिए निम्नलिखित कमांड का उपयोग करें। यहां आपको संबंधित उपयोगकर्ता का पासवर्ड प्रदान करना होगा जो आप सर्वर शुरू करने के लिए Oridb.sh फाइल में उल्लेख करते हैं।

$ service orientdb start

यह जानने के लिए कि ओरिएंटडीबी सर्वर डेमॉन किस पीआईडी ​​पर चल रहा है, निम्नलिखित कमांड का उपयोग करें।

$ service orientdb status

OrientDB सर्वर डेमॉन को रोकने के लिए निम्न आदेश का उपयोग करें। यहां आपको संबंधित उपयोगकर्ता का पासवर्ड प्रदान करना होगा, जिसका उल्लेख आप सर्वर को रोकने के लिए Oridb.sh फाइल में करते हैं।

$ service orientdb stop

विंडोज में

ओरिएंटबीडी एक सर्वर एप्लिकेशन है इसलिए इसे जावा वर्चुअल मशीन प्रक्रिया को बंद करने से पहले कई कार्य करने होंगे। यदि आप ओरिएंटबीडी सर्वर को मैन्युअल रूप से बंद करना चाहते हैं तो आपको निष्पादित करना होगाshutdown.batफ़ाइल। लेकिन सर्वर इंस्टेंस सही ढंग से बंद नहीं होता है, जब सिस्टम उपरोक्त स्क्रिप्ट को निष्पादित किए बिना अचानक बंद हो जाता है। ऑपरेटिंग सिस्टम द्वारा निर्दिष्ट संकेतों के एक सेट के साथ नियंत्रित किए जाने वाले कार्यक्रमों को कहा जाता हैservices विंडोज में।

हमें उपयोग करना है Apache Common Daemonजो विंडोज उपयोगकर्ताओं को विंडोज़ सेवा के रूप में जावा अनुप्रयोगों को लपेटने की अनुमति देता है। Apache आम डेमॉन को डाउनलोड करने और पंजीकृत करने की प्रक्रिया निम्नलिखित है।

  • विंडोज़ के लिए Apache Common Daemons के लिए निम्न लिंक पर क्लिक करें ।

  • पर क्लिक करें common-daemon-1.0.15-bin-windows डाउनलोड करने के लिए।

  • खोलना common-daemon-1.0.15-bin-windowsनिर्देशिका। निकालने के बाद आप पाएंगेprunsrv.exe तथा prunmgr.exeनिर्देशिका के अंदर फ़ाइलें। उन में -

    • prunsrv.exe फ़ाइल सेवाओं के रूप में अनुप्रयोग चलाने के लिए एक सेवा अनुप्रयोग है।

    • prunmgr.exe फ़ाइल विंडोज़ सेवाओं की निगरानी और कॉन्फ़िगर करने के लिए उपयोग किया जाने वाला एप्लिकेशन है।

  • OrientDB स्थापना फ़ोल्डर में जाएं → एक नई निर्देशिका बनाएं और इसे सेवा का नाम दें।

  • की प्रतिलिपि बनाएँ prunsrv.exe तथा prunmgr .exe इसे सेवा निर्देशिका में पेस्ट करें।

  • ओरिएंटडीबी को विंडोज सेवा के रूप में कॉन्फ़िगर करने के लिए, आपको एक छोटी स्क्रिप्ट निष्पादित करनी होगी जो विंडोज सेवा के रूप में prusrv.exe का उपयोग करती है।

  • विंडोज सेवाओं को परिभाषित करने से पहले, आपको सेवा के नाम के अनुसार prunsrv और prunmgr का नाम बदलना होगा। उदाहरण के लिए क्रमशः ओरिएंटबीडीग्राफ और ओरिएंटबीडीग्राफ। यहाँ OrientDBGraph सेवा का नाम है।

  • निम्नलिखित स्क्रिप्ट को नामांकित फ़ाइल में कॉपी करें installService.bat और इसे में रखें %ORIENTDB_HOME%\service\ निर्देशिका।

:: OrientDB Windows Service Installation 
@echo off 
rem Remove surrounding quotes from the first parameter 
set str=%~1 
rem Check JVM DLL location parameter 
if "%str%" == "" goto missingJVM 
set JVM_DLL=%str% 
rem Remove surrounding quotes from the second parameter 
set str=%~2 
rem Check OrientDB Home location parameter 
if "%str%" == "" goto missingOrientDBHome 
set ORIENTDB_HOME=%str%  


set CONFIG_FILE=%ORIENTDB_HOME%/config/orientdb-server-config.xml 
set LOG_FILE = %ORIENTDB_HOME%/config/orientdb-server-log.properties 
set LOG_CONSOLE_LEVEL = info 
set LOG_FILE_LEVEL = fine 
set WWW_PATH = %ORIENTDB_HOME%/www 
set ORIENTDB_ENCODING = UTF8 
set ORIENTDB_SETTINGS = -Dprofiler.enabled = true 
-Dcache.level1.enabled = false Dcache.level2.strategy = 1 
set JAVA_OPTS_SCRIPT = -XX:+HeapDumpOnOutOfMemoryError

  
rem Install service 
OrientDBGraphX.X.X.exe //IS --DisplayName="OrientDB GraphEd X.X.X" ^ 
--Description = "OrientDB Graph Edition, aka GraphEd, contains OrientDB server
integrated with the latest release of the TinkerPop Open Source technology 
stack supporting property graph data model." ^ 

--StartClass = com.orientechnologies.orient.server.OServerMain 
-StopClass = com.orientechnologies.orient.server.OServerShutdownMain ^
 
--Classpath = "%ORIENTDB_HOME%\lib\*" --JvmOptions 
"Dfile.Encoding = %ORIENTDB_ENCODING%; Djava.util.logging.config.file = "%LOG_FILE%";
Dorientdb.config.file = "%CONFIG_FILE%"; -Dorientdb.www.path = "%WWW_PATH%";
Dlog.console.level = %LOG_CONSOLE_LEVEL%; -Dlog.file.level = %LOG_FILE_LEVEL%;
Dorientdb.build.number = "@BUILD@"; -DORIENTDB_HOME = %ORIENTDB_HOME%" ^ 

--StartMode = jvm --StartPath = "%ORIENTDB_HOME%\bin" --StopMode = jvm 
-StopPath = "%ORIENTDB_HOME%\bin" --Jvm = "%JVM_DLL%" 
-LogPath = "%ORIENTDB_HOME%\log" --Startup = auto  

EXIT /B  

:missingJVM 
echo Insert the JVM DLL location 
goto printUsage 
 
:missingOrientDBHome 
echo Insert the OrientDB Home
goto printUsage 
 
:printUsage 
echo usage: 
echo     installService JVM_DLL_location OrientDB_Home 
EXIT /B

स्क्रिप्ट को दो मापदंडों की आवश्यकता है -

  • Jvm.dll का स्थान, उदाहरण के लिए C: \ ProgramFiles \ java \ jdk1.8.0_66 \ jre \ bin \ server \ jvm.dll

  • जैसे C: \ Oridb-Community-2.1.9 के लिए ओरिएंटबीडी इंस्टॉलेशन का स्थान

  • जब आप OrientDBGraph.exe फ़ाइल (मूल prunsrv) निष्पादित करते हैं और उस पर डबल-क्लिक करते हैं तो सेवा स्थापित हो जाती है।

  • Windows में सेवाएँ स्थापित करने के लिए निम्न कमांड का उपयोग करें।

> Cd %ORIENTDB_HOME%\service 
> installService.bat "C:\Program Files\Java\jdk1.8.0_66\jre\bin\server
   \jvm.dll" C:\orientdb-community-2.1.9

टास्क मैनेजर सेवाओं को खोलें, आपको निम्न स्क्रीनशॉट मिलेगा जिसमें पंजीकृत सेवा का नाम है।

चरण 4 - ओरिएंटबीडी इंस्टॉलेशन को सत्यापित करना

यह चरण निम्न चरणों का उपयोग करके ओरिएंटबीडी डेटाबेस सर्वर इंस्टॉलेशन की पुष्टि करता है।

  • सर्वर चलाएं।
  • कंसोल चलाएं।
  • स्टूडियो चलाएं।

यह ऑपरेटिंग सिस्टम के अनुसार अद्वितीय है।

लिनक्स में

Linux में OrientDB स्थापना की पुष्टि करने के लिए दी गई प्रक्रिया का पालन करें।

Running the server - सर्वर को शुरू करने के लिए आप निम्न कमांड का उपयोग कर सकते हैं।

$ cd $ORIENTDB_HOME/bin $ ./server.sh

या आप ओरिएंटडीबी सर्वर को UNIX डेमन के रूप में शुरू करने के लिए निम्न कमांड का उपयोग कर सकते हैं।

$ service orientdb start

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

.                                           
          .`        `                                  
          ,      `:.                                   
         `,`    ,:`                                    
         .,.   :,,                                     
         .,,  ,,,                                      
    .    .,.:::::  ````                                 :::::::::     :::::::::    
    ,`   .::,,,,::.,,,,,,`;;                      .:    ::::::::::    :::    :::   
    `,.  ::,,,,,,,:.,,.`  `                       .:    :::      :::  :::     :::  
     ,,:,:,,,,,,,,::.   `        `         ``     .:    :::      :::  :::     :::  
      ,,:.,,,,,,,,,: `::, ,,   ::,::`   : :,::`  ::::   :::      :::  :::    :::   
       ,:,,,,,,,,,,::,:   ,,  :.    :   ::    :   .:    :::      :::  :::::::      
        :,,,,,,,,,,:,::   ,,  :      :  :     :   .:    :::      :::  :::::::::    
  `     :,,,,,,,,,,:,::,  ,, .::::::::  :     :   .:    :::      :::  :::     :::  
  `,...,,:,,,,,,,,,: .:,. ,, ,,         :     :   .:    :::      :::  :::     ::: 
    .,,,,::,,,,,,,:  `: , ,,  :     `   :     :   .:    :::      :::  :::     :::  
      ...,::,,,,::.. `:  .,,  :,    :   :     :   .:    :::::::::::   :::     :::  
           ,::::,,,. `:   ,,   :::::    :     :   .:    :::::::::     ::::::::::   
           ,,:` `,,.                                   
          ,,,    .,`                                   
         ,,.     `,                                          GRAPH DATABASE   
       ``        `.                                                           
                 ``                                          orientdb.com 
                 `    
				 
2016-01-20 19:17:21:547 INFO  OrientDB auto-config DISKCACHE = 1, 
   649MB (heap = 494MB os = 4, 192MB disk = 199, 595MB) [orientechnologies] 
2016-01-20 19:17:21:816 INFO  Loading configuration from:
   /opt/orientdb/config/orientdb-server-config.xml... [OServerConfigurationLoaderXml] 
2016-01-20 19:17:22:213 INFO  OrientDB Server v2.1.9-SNAPSHOT 
   (build 2.1.x@r; 2016-01-07 10:51:24+0000) is starting up... [OServer] 
2016-01-20 19:17:22:220 INFO  Databases directory: /opt/orientdb/databases [OServer] 
2016-01-20 19:17:22:361 INFO  Port 0.0.0.0:2424 busy, 
   trying the next available... [OServerNetworkListener] 
2016-01-20 19:17:22:362 INFO  Listening binary connections on 0.0.0.0:2425 
   (protocol v.32, socket = default) [OServerNetworkListener] 
... 
2016-01-20 19:17:22:614 INFO  Installing Script interpreter. WARN:
   authenticated clients can execute any kind of code into the server 
   by using the following allowed languages: 
   [sql] [OServerSideScriptInterpreter] 
2016-01-20 19:17:22:615 INFO  OrientDB Server v2.1.9-SNAPSHOT 
   (build 2.1.x@r; 2016-01-07 10:51:24+0000) is active. [OServer]

Running the console - ओरिएंटबीडी को कंसोल के तहत चलाने के लिए आप निम्न कमांड का उपयोग कर सकते हैं।

$ orientdb

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

OrientDB console v.2.1.9-SNAPSHOT (build 2.1.x@r; 2016-01-07 10:51:24+0000) www.orientdb.com 
Type 'help' to display all the supported commands. 
Installing extensions for GREMLIN language v.2.6.0 
 
orientdb>

Running the Studio - सर्वर शुरू करने के बाद आप निम्न URL का उपयोग कर सकते हैं (http://localhost:2480/) आपके ब्राउज़र पर। आपको निम्न स्क्रीनशॉट मिलेगा।

विंडोज में

Windows में OrientDB स्थापना की पुष्टि करने के लिए दी गई प्रक्रिया का पालन करें।

Running the server - सर्वर को शुरू करने के लिए आप निम्न कमांड का उपयोग कर सकते हैं।

> cd %ORIENTDB_HOME%\bin 
> ./server.bat

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

.                                           
          .`        `                                  
          ,      `:.                                   
         `,`    ,:`                                    
         .,.   :,,    
		 .,,  ,,,                                      
    .    .,.:::::  ````                                 :::::::::     :::::::::    
    ,`   .::,,,,::.,,,,,,`;;                      .:    ::::::::::    :::    :::   
    `,.  ::,,,,,,,:.,,.`  `                       .:    :::      :::  :::     :::  
     ,,:,:,,,,,,,,::.   `        `         ``     .:    :::      :::  :::     :::  
      ,,:.,,,,,,,,,: `::, ,,   ::,::`   : :,::`  ::::   :::      :::  :::    :::   
       ,:,,,,,,,,,,::,:   ,,  :.    :   ::    :   .:    :::      :::  :::::::      
        :,,,,,,,,,,:,::   ,,  :      :  :     :   .:    :::      :::  :::::::::    
  `     :,,,,,,,,,,:,::,  ,, .::::::::  :     :   .:    :::      :::  :::     :::  
  `,...,,:,,,,,,,,,: .:,. ,, ,,         :     :   .:    :::      :::  :::     :::  
    .,,,,::,,,,,,,:  `: , ,,  :     `   :     :   .:    :::      :::  :::     :::  
      ...,::,,,,::.. `:  .,,  :,    :   :     :   .:    :::::::::::   :::     :::  
           ,::::,,,. `:   ,,   :::::    :     :   .:    :::::::::     ::::::::::   
           ,,:` `,,.                                   
          ,,,    .,`                                   
         ,,.     `,                                          GRAPH DATABASE   
       ``        `.                                                           
                 ``                                          orientdb.com 
                 `            
				 
2016-01-20 19:17:21:547 INFO  OrientDB auto-config DISKCACHE = 1,649MB 
   (heap = 494MB os = 4, 192MB disk = 199, 595MB) [orientechnologies] 
2016-01-20 19:17:21:816 INFO  Loading configuration from: 
   /opt/orientdb/config/orientdb-server-config.xml... 
   [OServerConfigurationLoaderXml] 
... 
2016-01-20 19:17:22:615 INFO  OrientDB Server v2.1.9-SNAPSHOT 
   (build 2.1.x@r; 2016-01-07 10:51:24+0000) is active. [OServer]

Running the console - कंसोल के तहत ओरिएंटडीबी चलाने के लिए आप निम्न कमांड का उपयोग कर सकते हैं।

> %ORIENTDB_HOME%\bin\console.bat

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

OrientDB console v.2.1.9-SNAPSHOT (build 2.1.x@r; 2016-01-07 10:51:24+0000) www.orientdb.com 
Type 'help' to display all the supported commands. 
Installing extensions for GREMLIN language v.2.6.0 
 
orientdb\>

Running the Studio - सर्वर शुरू करने के बाद आप निम्न URL का उपयोग कर सकते हैं (http://localhost:2480/) आपके ब्राउज़र पर। आपको निम्न स्क्रीनशॉट मिलेगा।

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

दस्तावेज़ मॉडल

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

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

निम्न तालिका संबंधपरक मॉडल, दस्तावेज़ मॉडल और ओरिएंटडीबी दस्तावेज़ मॉडल के बीच तुलना को दर्शाती है -

संबंधपरक मॉडल दस्तावेज़ मॉडल ओरिएंटडीबी दस्तावेज़ मॉडल
टेबल संग्रह कक्षा या क्लस्टर
पंक्ति डाक्यूमेंट डाक्यूमेंट
स्तंभ कुंजी / मूल्य जोड़ी दस्तावेज़ फ़ील्ड
संबंध उपलब्ध नहीं है संपर्क

ग्राफ मॉडल

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

निम्न तालिका ग्राफ़ मॉडल, संबंधपरक डेटा मॉडल और ओरिएंटबीडी ग्राफ़ मॉडल के बीच तुलना दिखाती है।

संबंधपरक मॉडल ग्राफ मॉडल ओरिएंटडीबी ग्राफ मॉडल
टेबल वर्टेक्स और एज क्लास वर्ग जो "V" (वर्टेक्स के लिए) और "E" (किनारों के लिए) का विस्तार करता है
पंक्ति शिखर शिखर
स्तंभ वर्टेक्स और एज प्रॉपर्टी वर्टेक्स और एज प्रॉपर्टी
संबंध एज एज

की / मूल्य मॉडल

की / वैल्यू मॉडल का मतलब है कि डेटा को कुंजी / वैल्यू पेयर के रूप में स्टोर किया जा सकता है, जहां मान सरल और जटिल प्रकार के हो सकते हैं। यह मूल्यों के रूप में दस्तावेजों और ग्राफ तत्वों का समर्थन कर सकता है।

निम्न तालिका संबंधपरक मॉडल, कुंजी / मूल्य मॉडल और ओरिएंटबीडी कुंजी / मूल्य मॉडल के बीच तुलना को दर्शाती है।

संबंधपरक मॉडल कुंजी / मूल्य मॉडल ओरिएंटबीडी कुंजी / मूल्य मॉडल
टेबल बाल्टी कक्षा या क्लस्टर
पंक्ति कुंजी / मूल्य जोड़ी डाक्यूमेंट
स्तंभ उपलब्ध नहीं है दस्तावेज़ फ़ील्ड या वर्टेक्स / एज प्रॉपर्टी
संबंध उपलब्ध नहीं है संपर्क

ऑब्जेक्ट मॉडल

यह मॉडल ऑब्जेक्ट ओरिएंटेड प्रोग्रामिंग और समर्थन द्वारा विरासत में मिला है Inheritance प्रकारों के बीच (उप-प्रकार सुपर-प्रकार का विस्तार करता है), Polymorphism जब आप एक बेस क्लास और देखें Direct binding से / प्रोग्रामिंग भाषाओं में उपयोग की जाने वाली वस्तुओं के लिए।

निम्न तालिका संबंधपरक मॉडल, ऑब्जेक्ट मॉडल और ओरिएंटबीडी ऑब्जेक्ट मॉडल के बीच तुलना को दर्शाती है।

संबंधपरक मॉडल ऑब्जेक्ट मॉडल ओरिएंटबीडी ऑब्जेक्ट मॉडल
टेबल कक्षा कक्षा या क्लस्टर
पंक्ति वस्तु दस्तावेज़ या वर्टेक्स
स्तंभ वस्तु संपत्ति दस्तावेज़ फ़ील्ड या वर्टेक्स / एज प्रॉपर्टी
संबंध सूचक संपर्क

विस्तार से आगे बढ़ने से पहले, ओरिएंटडीबी से जुड़ी मूल शब्दावली जानना बेहतर है। निम्नलिखित कुछ महत्वपूर्ण शब्दावली हैं।

अभिलेख

सबसे छोटी इकाई जिसे आप डेटाबेस में लोड और स्टोर कर सकते हैं। अभिलेखों को चार प्रकारों में संग्रहित किया जा सकता है।

  • Document
  • रिकॉर्ड बाइट्स
  • Vertex
  • Edge

रिकॉर्ड आईडी

जब OrientDB एक रिकॉर्ड बनाता है, डेटाबेस सर्वर स्वचालित रूप से रिकॉर्ड के लिए एक इकाई पहचानकर्ता प्रदान करता है, जिसे RecordID (RID) कहा जाता है। RID # <क्लस्टर>: <स्थिति> जैसा दिखता है। <क्लस्टर> का अर्थ है क्लस्टर पहचान संख्या और <स्थिति> का अर्थ है क्लस्टर में रिकॉर्ड की पूर्ण स्थिति।

दस्तावेज़

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

JSON प्रारूप में दस्तावेज़ों को आसानी से निर्यात और आयात द्वारा नियंत्रित किया जा सकता है। उदाहरण के लिए, निम्नलिखित JSON नमूना दस्तावेज़ पर एक नज़र डालें। यह दस्तावेज़ के विवरण को परिभाषित करता है।

{ 
   "id"        : "1201", 
   "name"      : "Jay", 
   "job"       : "Developer", 
   "creations" : [ 
      { 
         "name"    : "Amiga", 
         "company" : "Commodore Inc." 
      }, 
		
      { 
         "name"    : "Amiga 500", 
         "company" : "Commodore Inc." 
      } 
   ] 
}

RecordBytes

रिकॉर्ड प्रकार RDBMS में BLOB प्रकार के समान है। OrientDB बाइनरी डेटा के साथ दस्तावेज़ प्रकार को लोड और स्टोर कर सकता है।

शिखर

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

एज

एक अलग रिकॉर्ड प्रकार है जिसे एज कहा जाता है जो एक शीर्ष को दूसरे से जोड़ता है। किनारे द्विदिश हैं और केवल दो कोने जोड़ सकते हैं। ओरिएंटडीबी में दो प्रकार के किनारे हैं, एक नियमित है और दूसरा हल्का है।

कक्षा

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

समूह

क्लस्टर एक महत्वपूर्ण अवधारणा है जिसका उपयोग रिकॉर्ड, दस्तावेज़ या कोने को संग्रहीत करने के लिए किया जाता है। सरल शब्दों में, क्लस्टर एक ऐसी जगह है जहां रिकॉर्ड का एक समूह संग्रहीत किया जाता है। डिफ़ॉल्ट रूप से, OrientDB प्रति वर्ग एक क्लस्टर बनाएगा। एक वर्ग के सभी अभिलेखों को एक ही क्लस्टर में संग्रहीत किया जाता है, जिसमें कक्षा के समान नाम होता है। आप एक डेटाबेस में 32,767 (2 ^ 15-1) क्लस्टर बना सकते हैं।

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

रिश्तों

ओरिएंटबीडी दो प्रकार के संबंधों का समर्थन करता है: संदर्भित और एम्बेडेड। Referenced relationships इसका मतलब है कि यह रिश्तों की लक्षित वस्तुओं के लिए सीधा लिंक संग्रहीत करता है। Embedded relationshipsइसका मतलब है कि यह रिकॉर्ड के भीतर संबंध को संग्रहीत करता है जो इसे एम्बेड करता है। यह संबंध संदर्भ संबंध से अधिक मजबूत है।

डेटाबेस

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

ओरिएंटबीडी मूल रूप से कई डेटा प्रकारों का समर्थन करता है। इसके पीछे की पूरी तालिका है।

अनु क्रमांक। प्रकार विवरण
1 बूलियन

केवल मूल्यों को संभालता है सही या गलत।

Java types: java.lang.Boolean

Min: 0

Max: १

2 पूर्णांक

32-बिट हस्ताक्षरित पूर्णांक।

Java types: java.lang.Interger

Min: -2,147,483,648

Max: +2,147,483,647

3 कम

छोटे 16-बिट हस्ताक्षरित पूर्णांक।

Java types: java.lang.short

Min: -32,768

Max: 32,767

4 लंबा

बड़े 64-बिट पूर्णांक पर हस्ताक्षर किए।

Java types: java.lang.Long

Min: -2 63

Max: +2 63 -1

5 फ्लोट

दशमलव संख्याएं।

Java types: java.lang.Float

: २ -१४ ९

Max: (2-2 -23 ) * 2, 127

6 दोहरा

उच्च परिशुद्धता के साथ दशमलव संख्या।

Java types: Java.lang.Double।

Min: २ -१० 2४

Max: (2-2 -52 ) * 2 1023

7 दिनांक और समय

मिलीसेकंड तक की सटीकता के साथ कोई भी तारीख।

Java types: java.util.Date

8 तार

वर्णों के अल्फ़ान्यूमेरिक अनुक्रम के रूप में कोई स्ट्रिंग।

Java types: java.lang.String

9 बायनरी

बाइट सरणी के रूप में कोई भी मूल्य शामिल कर सकते हैं।

Java types: बाइट []

Min: 0

Max: 2,147,483,647

10 एम्बेडेड

रिकॉर्ड मालिक के अंदर निहित है। निहित रिकॉर्ड में कोई RecordId नहीं है।

Java types: ओरकॉर्ड

1 1 एंबेडेड सूची

रिकॉर्ड मालिक के अंदर निहित हैं। निहित रिकॉर्ड का कोई रिकॉर्ड नहीं है और केवल मालिक के रिकॉर्ड को नेविगेट करके पहुंच योग्य हैं।

Java types: सूची <ऑब्जेक्ट्स>

Min: 0

Max: 41,000,000 आइटम

12 एंबेडेड सेट

रिकॉर्ड मालिक के अंदर निहित हैं। निहित रिकॉर्ड में कोई RecordId नहीं है और केवल मालिक के रिकॉर्ड को नेविगेट करके उपलब्ध हैं।

Java types: <ऑब्जेक्ट्स> सेट करें

Min: 0

Max: 41,000,000 आइटम

13 एंबेडेड नक्शा

रिकॉर्ड स्वामी के अंदर प्रविष्टियों के मूल्यों के रूप में निहित हैं, जबकि चाबियाँ केवल तार हो सकती हैं। निहित रिकॉर्ड्स का कोई रिकॉर्डआईड नहीं है और केवल मालिक रिकॉर्ड को नेविगेट करके पहुंच योग्य हैं।

Java types: नक्शा <स्ट्रिंग, ऑर्कॉर्ड>

Min: 0

Max: 41,000,000 आइटम

14 संपर्क

एक और रिकॉर्ड से जुड़ा। यह एक आम रिश्ता है

Java Types: ओआरआईडी, <? Orecord> का विस्तार करता है

Min: १

Max: 32767: 2 ^ 63-1

15 लिंक सूची

अन्य अभिलेखों के लिंक यह एक आम-से-कई संबंध है जहां केवल रिकॉर्डआईड्स संग्रहीत हैं।

Java types: सूची <? Orecord> का विस्तार करता है

Min: 0

Max: 41,000,000 आइटम

16 लिंक सेट करें

अन्य अभिलेखों के लिंक यह एक आम रिश्ता है।

Java types: सेट करें <? Orecord> का विस्तार करता है

Min: 0

Max: 41,000,000 आइटम

17 लिंक मानचित्र

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

Java types: नक्शा <स्ट्रिंग,? रिकॉर्ड का विस्तार>

Min: 0

Max: 41,000,000 आइटम

18 बाइट

सिंगल बाइट। छोटे 8-बिट हस्ताक्षरित पूर्णांक को स्टोर करने के लिए उपयोगी।

Java types: java.lang.Byte

Min: -128

Max: +127

19 क्षणिक कोई भी मूल्य डेटाबेस पर संग्रहीत नहीं है।
20 दिनांक

वर्ष, महीने और दिन के रूप में कोई भी तारीख।

Java Types: java.util.Date

21 रिवाज

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

Java types: OSerializableStream

Min: 0

Max: एक्स

22 दशमलव

दशमलव संख्या बिना गोलाई के।

Java types: java.math.BigDecimal

23 LinkBag

विशिष्ट रीडबग के रूप में रिकॉर्ड्स की सूची।

Java types: ओरिडबाग

24 कोई भी

मिश्रित प्रकार, और अशक्त के संग्रह को निर्दिष्ट करने के लिए निर्धारित प्रकार का निर्धारण नहीं।

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

OrientDB कंसोल ओरिएंटडीबी डेटाबेस और सर्वर इंस्टेंस के खिलाफ काम करने के लिए बनाया गया जावा एप्लिकेशन है। कई कंसोल मोड हैं जो ओरिएंटबीडी का समर्थन करते हैं।

इंटरएक्टिव मोड

यह डिफ़ॉल्ट मोड है। बस निम्नलिखित स्क्रिप्ट को निष्पादित करके कंसोल लॉन्च करेंbin/console.sh (या bin/console.batएमएस विंडोज सिस्टम में)। उस पर निष्पादन की अनुमति सुनिश्चित करें।

OrientDB console v.1.6.6 www.orientechnologies.com 
Type 'help' to display all the commands supported.
  
orientdb>

एक बार हो जाने के बाद, कंसोल कमांड को स्वीकार करने के लिए तैयार है।

बैच मोड

बैच मोड में कमांड निष्पादित करने के लिए निम्नलिखित चलाएँ bin/console.sh (या bin/console.bat एमएस विंडोज सिस्टम में) स्क्रिप्ट अर्धविराम के साथ अलग किए गए सभी आदेशों को पारित कर रही है ";"।

orientdb> console.bat "connect remote:localhost/demo;select * from profile"

या पाठ स्क्रिप्ट में फ़ाइल के नाम से गुजरने वाली कंसोल स्क्रिप्ट को कॉल करें जिसमें निष्पादित करने के लिए कमांड की सूची है। कमांड को अर्धविराम से अलग किया जाना चाहिए ";"।

उदाहरण

Command.txt में उन आदेशों की सूची है, जिन्हें आप OrientDB कंसोल के माध्यम से निष्पादित करना चाहते हैं। निम्न आदेश Command.txt फ़ाइल से आदेशों के बैच को स्वीकार करता है।

orientdb> console.bat commands.txt

बैच मोड में, आप त्रुटियों को अनदेखा कर सकते हैं स्क्रिप्ट को "ignErrors" चर को सही पर सेट करके निष्पादन को जारी रखने दें।

orientdb> set ignoreErrors true

इको सक्षम करें

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

orientdb> set echo true

OrientDB डेटाबेस का SQL संदर्भ डेटाबेस बनाने, बदलने और ड्रॉप करने के लिए कई कमांड प्रदान करता है।

निम्न कथन क्रिएट डेटाबेस कमांड का एक बेसिक सिंटैक्स है।

CREATE DATABASE <database-url> [<user> <password> <storage-type> [<db-type>]]

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

<database-url>- डेटाबेस के URL को परिभाषित करता है। URL में दो भाग हैं, एक है <मोड> और दूसरा है <path>।

<mode> - मोड, यानी स्थानीय मोड या रिमोट मोड को परिभाषित करता है।

<path> - डेटाबेस के लिए मार्ग को परिभाषित करता है।

<user> - उस उपयोगकर्ता को परिभाषित करता है जिसे आप डेटाबेस से कनेक्ट करना चाहते हैं।

<password> - डेटाबेस से कनेक्ट करने के लिए पासवर्ड को परिभाषित करता है।

<storage-type>- भंडारण प्रकार को परिभाषित करता है। आप PLOCAL और MEMORY के बीच चयन कर सकते हैं।

उदाहरण

डेमो नामक एक स्थानीय डेटाबेस बनाने के लिए आप निम्न कमांड का उपयोग कर सकते हैं।

Orientdb> CREATE DATABASE PLOCAL:/opt/orientdb/databses/demo

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

Database created successfully. 
Current database is: plocal: /opt/orientdb/databases/demo

orientdb {db = demo}>

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

निम्न कथन ऑल्टर डेटाबेस कमांड का मूल सिंटैक्स है।

ALTER DATABASE <attribute-name> <attribute-value>

कहाँ पे <attribute-name> उस विशेषता को परिभाषित करता है जिसे आप संशोधित करना चाहते हैं और <attributevalue> उस विशेषता के लिए आपके द्वारा निर्धारित मूल्य को परिभाषित करता है।

निम्न तालिका डेटाबेस को बदलने के लिए समर्थित विशेषताओं की सूची को परिभाषित करती है।

अनु क्रमांक। उत्तरदायी ठहराने के लिए नाम विवरण
1 स्थिति विभिन्न विशेषताओं के बीच डेटाबेस की स्थिति को परिभाषित करता है।
2 आयात आयात स्थिति सेट करता है।
3 DEFAULTCLUSTERID आईडी का उपयोग करके डिफ़ॉल्ट क्लस्टर सेट करता है। डिफ़ॉल्ट रूप से यह 2 है।
4 डेटा प्रारूप डिफ़ॉल्ट के रूप में विशेष दिनांक प्रारूप सेट करता है। डिफ़ॉल्ट रूप से यह "yyyy-MM-dd" है।
5 DATETIMEFORMAT डिफ़ॉल्ट के रूप में विशेष दिनांक समय प्रारूप सेट करता है। डिफ़ॉल्ट रूप से यह "yyyy-MM-dd HH: mm: ss" है।
6 समय क्षेत्र विशेष समय क्षेत्र सेट करता है। डिफ़ॉल्ट रूप से यह जावा वर्चुअल मशीन (JVM) का डिफ़ॉल्ट समय क्षेत्र है।
7 LOCALECOUNTRY डिफ़ॉल्ट लोकेल देश सेट करता है। डिफ़ॉल्ट रूप से यह JVM का डिफ़ॉल्ट स्थानीय देश है। उदाहरण के लिए: "जीबी"।
8 LOCALELANGUAGE डिफ़ॉल्ट लोकेल भाषा सेट करता है। डिफ़ॉल्ट रूप से यह JVM की डिफ़ॉल्ट स्थानीय भाषा है। उदाहरण के लिए: "एन"।
9 CHARSET वर्ण सेट का प्रकार सेट करता है। डिफ़ॉल्ट रूप से यह JVM का डिफ़ॉल्ट चारसेट है। उदाहरण के लिए: "utf8"।
10 CLUSTERSELECTION क्लस्टर का चयन करने के लिए उपयोग की जाने वाली डिफ़ॉल्ट रणनीति सेट करता है। इन रणनीतियों को वर्ग निर्माण के साथ बनाया जाता है। समर्थित रणनीतियाँ डिफ़ॉल्ट, राउंडरोबिन और संतुलित हैं।
1 1 MINIMUMCLUSTERS जब एक नया वर्ग बनाया जाता है तो स्वचालित रूप से बनाने के लिए क्लस्टर की न्यूनतम संख्या निर्धारित करता है। डिफ़ॉल्ट रूप से यह 1 है।
12 कस्टम कस्टम गुण सेट करता है।
13 सत्यापन संपूर्ण डेटाबेस के लिए मान्यताओं को अक्षम या सक्षम करता है।

उदाहरण

OrientDB-2.2 के संस्करण से, नया SQL पार्सर जोड़ा जाता है जो कुछ मामलों में नियमित वाक्यविन्यास की अनुमति नहीं देगा। इसलिए, हमें कुछ मामलों में नए SQL पार्सर (StrictSQL) को निष्क्रिय करना होगा। StrictSQL पार्सर को अक्षम करने के लिए आप निम्न ऑल्टर डेटाबेस कमांड का उपयोग कर सकते हैं।

orientdb> ALTER DATABASE custom strictSQL = false

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

Database updated successfully

RDBMS की तरह, OrientDB भी बैकअप का समर्थन करता है और संचालन को पुनर्स्थापित करता है। बैकअप ऑपरेशन को निष्पादित करते समय, यह ज़िप एल्गोरिथ्म का उपयोग करके वर्तमान डेटाबेस की सभी फ़ाइलों को एक संपीड़ित ज़िप प्रारूप में ले जाएगा। यह सुविधा (बैकअप) स्वचालित-बैकअप सर्वर प्लगइन को सक्षम करके स्वचालित रूप से लाभ उठाया जा सकता है।

डेटाबेस का बैकअप लेना या डेटाबेस का निर्यात करना समान है, हालाँकि, प्रक्रिया के आधार पर हमें यह जानना होगा कि बैकअप का उपयोग कब करना है और निर्यात का उपयोग कब करना है।

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

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

निम्न कथन डेटाबेस बैकअप का मूल सिंटैक्स है।

./backup.sh <dburl> <user> <password> <destination> [<type>]

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

<dburl> - डेटाबेस URL जहां डेटाबेस या तो स्थानीय या दूरस्थ स्थान में स्थित है।

<user> - बैकअप चलाने के लिए उपयोगकर्ता नाम निर्दिष्ट करता है।

<password> - विशेष उपयोगकर्ता के लिए पासवर्ड प्रदान करता है।

<destination> - गंतव्य फ़ाइल स्थान बताते हुए कि बैकअप ज़िप फ़ाइल कहाँ संग्रहीत करें।

<type>- वैकल्पिक बैकअप प्रकार। इसके दो विकल्प हैं।

  • डिफ़ॉल्ट - बैकअप के दौरान डेटाबेस को लॉक करता है।

  • LVM - पृष्ठभूमि में LVM कॉपी-ऑन-राइट स्नैपशॉट का उपयोग करता है।

उदाहरण

डेटाबेस डेमो का एक बैकअप लें, जो स्थानीय फ़ाइल सिस्टम / ऑप्ट / ओरिएंटब / डेटाबेस / डेमो में नमूना- demo.zip नामक फ़ाइल में और वर्तमान निर्देशिका में स्थित है।

डेटाबेस डेमो का बैकअप लेने के लिए आप निम्न कमांड का उपयोग कर सकते हैं।

$ backup.sh plocal: opt/orientdb/database/demo admin admin ./backup-demo.zip

कंसोल का उपयोग करना

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

orientdb> CONNECT PLOCAL:/opt/orientdb/databases/demo admin admin

कनेक्ट करने के बाद आप मौजूदा डायरेक्टरी में 'backup-demo.zip' नामक फाइल में डेटाबेस का बैकअप लेने के लिए निम्न कमांड का उपयोग कर सकते हैं।

orientdb {db=demo}> BACKUP DATABASE ./backup-demo.zip

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

Backup executed in 0.30 seconds

RDBMS की तरह, OrientDB भी संचालन बहाल करने का समर्थन करता है। केवल कंसोल मोड से, आप इस ऑपरेशन को सफलतापूर्वक निष्पादित कर सकते हैं।

निम्नलिखित कथन संचालन बहाल करने के लिए मूल वाक्यविन्यास है।

orientdb> RESTORE DATABSE <url of the backup zip file>

उदाहरण

आपको यह ऑपरेशन केवल कंसोल मोड से करना होगा। इसलिए, पहले आपको निम्न ओरिएंटबीडी कमांड का उपयोग करके ओरिएंटबीडी कंसोल शुरू करना होगा।

$ orientdb

फिर, बैकअप को पुनर्स्थापित करने के लिए संबंधित डेटाबेस से कनेक्ट करें। डेमो नामक डेटाबेस से कनेक्ट करने के लिए आप निम्न कमांड का उपयोग कर सकते हैं।

orientdb> CONNECT PLOCAL:/opt/orientdb/databases/demo admin admin

सफल कनेक्शन के बाद, आप 'backup-demo.zip' फ़ाइल से बैकअप को पुनर्स्थापित करने के लिए निम्न कमांड का उपयोग कर सकते हैं। निष्पादित करने से पहले, सुनिश्चित करें कि बैकअप- demo.zip फ़ाइल को वर्तमान निर्देशिका में रखा गया है।

Orientdb {db = demo}> RESTORE DATABASE backup-demo.zip

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

Database restored in 0.26 seconds

यह अध्याय बताता है कि ओरिएंटबीडी कमांड लाइन से किसी विशेष डेटाबेस से कैसे कनेक्ट किया जाए। यह एक डेटाबेस खोलता है।

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

CONNECT <database-url> <user> <password>

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

<database-url>- डेटाबेस के URL को परिभाषित करता है। URL में दो भाग हैं एक है <मोड> और दूसरा है <path>।

<mode> - मोड, यानी स्थानीय मोड या रिमोट मोड को परिभाषित करता है।

<path> - डेटाबेस के लिए मार्ग को परिभाषित करता है।

<user> - उस उपयोगकर्ता को परिभाषित करता है जिसे आप डेटाबेस से कनेक्ट करना चाहते हैं।

<password> - डेटाबेस से कनेक्ट करने के लिए पासवर्ड को परिभाषित करता है।

उदाहरण

हमने पहले ही पिछले अध्यायों में 'डेमो' नामक एक डेटाबेस बनाया है। इस उदाहरण में, हम उपयोगकर्ता व्यवस्थापक का उपयोग करके उससे कनेक्ट करेंगे।

डेमो डेटाबेस से कनेक्ट करने के लिए आप निम्न कमांड का उपयोग कर सकते हैं।

orientdb> CONNECT PLOCAL:/opt/orientdb/databases/demo admin admin

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

Connecting to database [plocal:/opt/orientdb/databases/demo] with user 'admin'…OK 
Orientdb {db = demo}>

यह अध्याय बताता है कि ओरिएंटबीडी कमांड लाइन से किसी विशेष डेटाबेस को कैसे डिस्कनेक्ट किया जाए। यह वर्तमान में खुले डेटाबेस को बंद कर देता है।

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

DISCONNECT

Note - आप किसी विशेष डेटाबेस से कनेक्ट होने के बाद ही इस कमांड का उपयोग कर सकते हैं और यह केवल वर्तमान में चल रहे डेटाबेस को बंद कर देगा।

उदाहरण

इस उदाहरण में, हम उसी डेटाबेस का उपयोग करेंगे जिसका नाम 'डेमो' है जिसे हमने पिछले अध्याय में बनाया था। हम डेमो डेटाबेस से डिस्कनेक्ट करेंगे।

डेटाबेस को डिस्कनेक्ट करने के लिए आप निम्न कमांड का उपयोग कर सकते हैं।

orientdb {db = demo}> DISCONNECT

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

Disconnecting to database [plocal:/opt/orientdb/databases/demo] with user 'admin'…OK 
orientdb>

यह अध्याय बताता है कि ओरिएंटबीडी कमांड लाइन से किसी विशेष डेटाबेस की जानकारी कैसे प्राप्त करें।

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

info

Note - आप किसी विशेष डेटाबेस से कनेक्ट होने के बाद ही इस कमांड का उपयोग कर सकते हैं और यह केवल वर्तमान में चल रहे डेटाबेस की जानकारी को पुनः प्राप्त करेगा।

उदाहरण

इस उदाहरण में, हम उसी डेटाबेस का उपयोग करेंगे जिसका नाम 'डेमो' है जिसे हमने पिछले अध्याय में बनाया था। हम डेमो डेटाबेस से बुनियादी जानकारी प्राप्त करेंगे।

डेटाबेस को डिस्कनेक्ट करने के लिए आप निम्न कमांड का उपयोग कर सकते हैं।

orientdb {db = demo}> info

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

Current database: demo (url = plocal:/opt/orientdb/databases/demo)
  
DATABASE PROPERTIES 
--------------------------------+---------------------------------------------+ 
 NAME                           | VALUE                                       | 
--------------------------------+---------------------------------------------+ 
 Name                           | null                                        | 
 Version                        | 14                                          | 
 Conflict Strategy              | version                                     | 
 Date format                    | yyyy-MM-dd                                  | 
 Datetime format                | yyyy-MM-dd HH:mm:ss                         | 
 Timezone                       | Asia/Kolkata                                | 
 Locale Country                 | IN                                          | 
 Locale Language                | en                                          | 
 Charset                        | UTF-8                                       | 
 Schema RID                     | #0:1                                        | 
 Index Manager RID              | #0:2                                        | 
 Dictionary RID                 | null                                        | 
--------------------------------+---------------------------------------------+

DATABASE CUSTOM PROPERTIES: 
 +-------------------------------+--------------------------------------------+ 
 | NAME                          | VALUE                                      | 
 +-------------------------------+--------------------------------------------+ 
 | strictSql                     | true                                       | 
 +-------------------------------+--------------------------------------------+  
CLUSTERS (collections) 
---------------------------------+-------+-------------------+----------------+ 
 NAME                            | ID    | CONFLICT STRATEGY | RECORDS        | 
---------------------------------+-------+-------------------+----------------+

यह अध्याय बताता है कि ओरिएंटडीबी कमांड लाइन से एक उदाहरण में सभी डेटाबेस की सूची कैसे प्राप्त करें।

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

LIST DATABASES

Note - इस कमांड का इस्तेमाल आप लोकल या रिमोट सर्वर से कनेक्ट करने के बाद ही कर सकते हैं।

उदाहरण

डेटाबेस की सूची प्राप्त करने से पहले, हमें रिमोट सर्वर के माध्यम से लोकलहोस्ट सर्वर से जुड़ना होगा। यह याद दिलाना आवश्यक है कि लोकलहोस्ट उदाहरण से जुड़ने के लिए उपयोगकर्ता नाम और पासवर्ड क्रमशः अतिथि और अतिथि है, जिसे में कॉन्फ़िगर किया गया हैorintdb/config/orientdb-server-config.xml फ़ाइल।

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

orientdb> connect remote:localhost guest

यह पासवर्ड पूछेगा। अतिथि के लिए कॉन्फ़िगर फ़ाइल पासवर्ड के अनुसार भी अतिथि है। यदि यह सफलतापूर्वक जुड़ा हुआ है, तो आपको निम्न आउटपुट मिलेगा।

Connecting to remote Server instance [remote:localhost] with user 'guest'...OK 
orientdb {server = remote:localhost/}>

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

orientdb {server = remote:localhost/}> list databases

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

Found 6 databases: 
* demo (plocal) 
* s2 (plocal) 
* s1 (plocal) 
* GratefulDeadConcerts (plocal) 
* s3 (plocal) 
* sample (plocal) 
orientdb {server = remote:localhost/}>

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

इस अध्याय में, आप सीख सकते हैं कि डेटाबेस को ओरिएंटडीबी कमांड लाइन से कैसे मुक्त किया जाए।

निम्न कथन फ्रीज़ डेटाबेस कमांड का मूल सिंटैक्स है।

FREEZE DATABASE

Note - आप इस कमांड का उपयोग केवल रिमोट या लोकल डेटाबेस में किसी विशेष डेटाबेस से कनेक्ट करने के बाद कर सकते हैं।

उदाहरण

इस उदाहरण में, हम उसी डेटाबेस का उपयोग करेंगे जिसका नाम 'डेमो' है जिसे हमने पिछले अध्याय में बनाया था। हम इस डेटाबेस को सीएलआई से मुक्त करेंगे।

डेटाबेस को फ्रीज करने के लिए आप निम्न कमांड का उपयोग कर सकते हैं।

Orientdb {db = demo}> FREEZE DATABASE

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

Database 'demo' was frozen successfully

इस अध्याय में, आप सीख सकते हैं कि डेटाबेस को फ्रीज राज्य से ओरिएंटबीडी कमांड लाइन के माध्यम से कैसे जारी किया जाए।

निम्न कथन रिलीज़ डेटाबेस कमांड का मूल सिंटैक्स है।

RELEASE DATABASE

Note - आप इस कमांड का उपयोग किसी विशेष डेटाबेस से कनेक्ट करने के बाद ही कर सकते हैं, जो फ्रीज अवस्था में है।

उदाहरण

इस उदाहरण में, हम उसी डेटाबेस का उपयोग करेंगे जिसका नाम 'डेमो' है जिसे हमने पिछले अध्याय में बनाया था। हम पिछले अध्याय में फ्रीज किए गए डेटाबेस को जारी करेंगे।

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

Orientdb {db = demo}> RELEASE DATABASE

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

Database 'demo' was release successfully

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

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

निम्न कथन कॉन्फ़िगरेशन डेटाबेस कमांड का मूल सिंटैक्स है।

CONFIG

Note - आप किसी विशेष डेटाबेस से कनेक्ट करने के बाद ही इस कमांड का उपयोग कर सकते हैं।

उदाहरण

इस उदाहरण में, हम उसी डेटाबेस का उपयोग करेंगे जिसका नाम 'डेमो' है जिसे हमने पिछले अध्याय में बनाया था।

डेमो डेटाबेस के कॉन्फ़िगरेशन को प्रदर्शित करने के लिए आप निम्न कमांड का उपयोग कर सकते हैं।

Orientdb {db = demo}> CONFIG

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

LOCAL SERVER CONFIGURATION: 
+---------------------------------------+-------------------------+ 
| NAME                                  | VALUE                   | 
+---------------------------------------+-------------------------+ 
| environment.dumpCfgAtStartup          | false                   | 
| environment.concurrent                | true                    | 
| environment.allowJVMShutdown          | true                    | 
| script.pool.maxSize                   | 20                      | 
| memory.useUnsafe                      | true                    | 
| memory.directMemory.safeMode          | true                    | 
| memory.directMemory.trackMode         | false                   | 
|………………………………..                         |                         | 
| storage.lowestFreeListBound           | 16                      | 
| network.binary.debug                  | false                   | 
| network.http.maxLength                | 1000000                 | 
| network.http.charset                  | utf-8                   | 
| network.http.jsonResponseError        | true                    | 
| network.http.json                     | false                   | 
| tx.log.fileType                       | classic                 | 
| tx.log.synch                          | false                   | 
| tx.autoRetry                          | 1                       | 
| client.channel.minPool                | 1                       | 
| storage.keepOpen                      | true                    | 
| cache.local.enabled                   | true                    | 
+---------------------------------------+-------------------------+ 
orientdb {db = demo}>

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

विन्यास सेट

आप कॉन्फ़िगरेशन चर मान का उपयोग करके अद्यतन कर सकते हैं CONFIG SET आदेश।

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

CONFIG SET <config-variable> <config-value>

Note - आप किसी विशेष डेटाबेस से कनेक्ट करने के बाद ही इस कमांड का उपयोग कर सकते हैं।

उदाहरण

इस उदाहरण में, हम उसी डेटाबेस का उपयोग करेंगे जिसका नाम 'डेमो' है जिसे हमने पिछले अध्याय में बनाया था। हम 'tx.autoRetry' वेरिएबल वैल्यू को 5 में संशोधित करेंगे।

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

orientdb {db = demo}> CONFIG SET tx.autoRetry 5

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

Local configuration value changed correctly

विन्यास प्राप्त करें

आप कॉन्फ़िगरेशन चर मान का उपयोग करके प्रदर्शित कर सकते हैं CONFIG GET आदेश।

निम्न कथन विन्यास प्राप्त कमांड का मूल सिंटैक्स है।

CONFIG GET <config-variable>

Note - आप किसी विशेष डेटाबेस से कनेक्ट करने के बाद ही इस कमांड का उपयोग कर सकते हैं।

उदाहरण

इस उदाहरण में, हम उसी डेटाबेस का उपयोग करेंगे जिसका नाम 'डेमो' है जिसे हमने पिछले अध्याय में बनाया था। हम 'tx.autoRetry' वैरिएबल मान को पुनः प्राप्त करने का प्रयास करेंगे।

डेमो डेटाबेस के कॉन्फ़िगरेशन को प्रदर्शित करने के लिए आप निम्न कमांड का उपयोग कर सकते हैं।

orientdb {db = demo}> CONFIG GET tx.autoRetry

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

Local configuration: tx.autoRetry = 5

RDBMS की तरह, OrientDB भी डेटाबेस निर्यात और आयात जैसी सुविधाएँ प्रदान करता है। ओरिएंटबैंक डेटा निर्यात करने के लिए JSON प्रारूप का उपयोग करता है। डिफ़ॉल्ट रूप से निर्यात कमांड फ़ाइलों को संपीड़ित करने के लिए GZIP एल्गोरिथ्म का उपयोग कर रहा है।

एक डेटाबेस निर्यात करते समय यह डेटाबेस को लॉक नहीं कर रहा है, जिसका अर्थ है कि आप समवर्ती पढ़ने और उस पर संचालन लिख सकते हैं। इसका मतलब यह भी है कि आप समवर्ती पढ़ने और लिखने के संचालन के कारण उस डेटा की एक सटीक प्रतिलिपि बना सकते हैं।

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

निम्न कथन निर्यात डेटाबेस कमांड का मूल सिंटैक्स है।

EXPORT DATABASE <output file>

Note - आप किसी विशेष डेटाबेस से कनेक्ट करने के बाद ही इस कमांड का उपयोग कर सकते हैं।

उदाहरण

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

orientdb {db = demo}> EXPORT DATABASE ./export-demo.export

यदि इसे सफलतापूर्वक निष्पादित किया जाता है, तो यह ऑपरेटिंग सिस्टम के आधार पर 'Export-demo.zip' या 'exportdemo.gz' नामक एक फाइल बनाएगा और आपको निम्न आउटपुट मिलेगा।

Exporting current database to: DATABASE /home/linuxtp/Desktop/demo.export in 
GZipped JSON format ...  

Started export of database 'demo' to /home/linuxtp/Desktop/demo.export.gz... 
Exporting database info...OK 
Exporting clusters...OK (12 clusters) 
Exporting schema...OK (11 classes) 
Exporting records... 
- Cluster 'internal' (id = 0)...OK (records = 3/3) 
- Cluster 'index' (id = 1)...OK (records = 0/0) 
- Cluster 'manindex' (id = 2)...OK (records = 0/0) 
- Cluster 'default' (id = 3)...OK (records = 0/0) 
- Cluster 'orole' (id = 4)...OK (records = 3/3) 
- Cluster 'ouser' (id = 5)...OK (records = 3/3) 
- Cluster 'ofunction' (id = 6)...OK (records = 0/0)
- Cluster 'oschedule' (id = 7)...OK (records = 0/0) 
- Cluster 'orids' (id = 8)...OK (records = 0/0) 
- Cluster 'v' (id = 9)...OK (records = 0/0) 
- Cluster 'e' (id = 10)...OK (records = 0/0) 
- Cluster '_studio' (id = 11)...OK (records = 1/1)  

Done. Exported 10 of total 10 records  

Exporting index info... 
- Index dictionary...OK 
- Index OUser.name...OK 
- Index ORole.name...OK 
OK (3 indexes) 
Exporting manual indexes content... 
- Exporting index dictionary ...OK (entries = 0) 
OK (1 manual indexes)  

Database export completed in 377ms

जब भी आप डेटाबेस को आयात करना चाहते हैं, तो आपको JSON प्रारूप निर्यात की गई फ़ाइल का उपयोग करना होगा, जो कि निर्यात कमांड द्वारा बनाई गई है।

इस अध्याय में आप सीख सकते हैं कि ओरिएंटबीडी कमांड लाइन से डेटाबेस को कैसे आयात किया जाए।

निम्न कथन आयात डेटाबेस कमांड का मूल सिंटैक्स है।

IMPORT DATABASE <input file>

Note - आप किसी विशेष डेटाबेस से कनेक्ट करने के बाद ही इस कमांड का उपयोग कर सकते हैं।

उदाहरण

इस उदाहरण में, हम उसी डेटाबेस का उपयोग करेंगे जिसका नाम 'डेमो' है जिसे हमने पिछले अध्याय में बनाया था। डेटाबेस को 'Export-Demo.gz' नामक फ़ाइल में आयात करने के लिए आप निम्न कमांड का उपयोग कर सकते हैं।

orientdb {db = demo}> IMPORT DATABASE ./export-demo.export.gz

यदि इसे सफलतापूर्वक निष्पादित किया जाता है, तो आपको सफल अधिसूचना के साथ-साथ निम्नलिखित आउटपुट मिलेंगे।

Database import completed in 11612ms

RDBMS के समान, OrientDB भी कमिट और रोलबैक जैसी लेनदेन अवधारणाएं प्रदान करता है। Commit डेटाबेस में सभी परिवर्तनों को सहेजकर लेनदेन को बंद करने का संदर्भ देता है। Rollback उस बिंदु पर डेटाबेस स्थिति को पुनर्प्राप्त करने के लिए संदर्भित करता है जहां आपने लेनदेन खोला था।

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

COMMIT

Note - आप इस कमांड का उपयोग किसी विशेष डेटाबेस से कनेक्ट करने और लेनदेन शुरू करने के बाद ही कर सकते हैं।

उदाहरण

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

सबसे पहले, निम्नलिखित का उपयोग करके लेनदेन शुरू करें BEGIN आदेश।

orientdb {db = demo}> BEGIN

उसके बाद, एक कर्मचारी तालिका में मान id = 12 और name = satish.P के साथ एक रिकॉर्ड डालें।

orientdb> INSERT INTO employee (id, name) VALUES (12, 'satish.P')

लेन-देन करने के लिए आप निम्न आदेश का उपयोग कर सकते हैं।

orientdb> commit

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

Transaction 2 has been committed in 4ms

इस अध्याय में, आप सीखेंगे कि ओरिएंटबीडी कमांड लाइन इंटरफ़ेस के माध्यम से अन-कमिटेड लेन-देन को कैसे रोल करें।

निम्न कथन रोलबैक डेटाबेस कमांड का मूल सिंटैक्स है।

ROLLBACK

Note - आप इस कमांड का उपयोग किसी विशेष डेटाबेस से कनेक्ट करने और लेनदेन शुरू करने के बाद ही कर सकते हैं।

उदाहरण

इस उदाहरण में, हम उसी डेटाबेस का उपयोग करेंगे जिसका नाम 'डेमो' है जिसे हमने पिछले अध्याय में बनाया था। हम रोलबैक लेन-देन के संचालन को देखेंगे और लेनदेन का उपयोग करके एक रिकॉर्ड स्टोर करेंगे।

सबसे पहले, निम्नलिखित का उपयोग करके लेनदेन शुरू करें BEGIN आदेश।

orientdb {db = demo}> BEGIN

उसके बाद, एक कर्मचारी तालिका में मान id = 12 और name = satish.P के साथ एक रिकॉर्ड डालें।

orientdb> INSERT INTO employee (id, name) VALUES (12, 'satish.P')

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

orientdb> SELECT FROM employee WHERE name LIKE '%.P'

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

---+-------+-------------------- 
 # | ID   | name 
---+-------+-------------------- 
 0 | 12   | satish.P 
---+-------+-------------------- 
1 item(s) found. Query executed in 0.076 sec(s).

अब आप इस लेनदेन को रोलबैक करने के लिए निम्न कमांड का उपयोग कर सकते हैं।

orientdb> ROLLBACK

कर्मचारी तालिका से समान रिकॉर्ड प्राप्त करने के लिए फिर से चयन करें क्वेरी की जाँच करें।

orientdb> SELECT FROM employee WHERE name LIKE '%.P'

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

0 item(s) found. Query executed in 0.037 sec(s).

तकनीकी शब्दावली के अनुसार Optimizationका अर्थ है "समय की सबसे तेज राशि में बेहतर संभव प्रदर्शन हासिल करना।" डेटाबेस के संदर्भ में, अनुकूलन में गति और दक्षता को अधिकतम करना शामिल है जिसके साथ डेटा पुनर्प्राप्त किया जाता है।

ओरिएंटबीडी हल्के किनारों का समर्थन करता है, जिसका अर्थ डेटा संस्थाओं के बीच सीधा संबंध है। सरल शब्दों में, यह क्षेत्र-से-क्षेत्र का संबंध है। डेटाबेस को ऑप्टिमाइज़ करने के लिए ओरिएंटबीडी अलग-अलग तरीके प्रदान करता है। यह हल्के किनारों के लिए नियमित किनारों के रूपांतरण का समर्थन करता है।

निम्न कथन ऑप्टिमाइज़ डेटाबेस कमांड का मूल सिंटैक्स है।

OPTMIZE DATABASE [-lwedges] [-noverbose]

कहाँ पे lwedges नियमित किनारों को हल्के किनारों में परिवर्तित करता है और noverbose आउटपुट अक्षम करता है।

उदाहरण

इस उदाहरण में, हम उसी डेटाबेस का उपयोग करेंगे जिसका नाम 'डेमो' है जिसे हमने पिछले अध्याय में बनाया था। आप निम्न ऑप्टिमाइज़ डेटाबेस कमांड का उपयोग कर सकते हैं।

OPTIMIZE DATABASE -lwedges

यदि इसे सफलतापूर्वक निष्पादित किया जाता है, तो आपको पूर्ण संदेश के साथ कुछ सफल सूचनाएं मिलेंगी।

Database Optimization completed in 35ms

RDBMS के समान, OrientDB एक डेटाबेस ड्रॉप करने की सुविधा प्रदान करता है। Drop database एक डेटाबेस को पूरी तरह से हटाने के लिए संदर्भित करता है।

निम्न कथन ड्रॉप डेटाबेस कमांड का मूल सिंटैक्स है।

DROP DATABASE [<database-name> <server-username> <server-user-password>]

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

<database-name> - डेटाबेस का नाम जिसे आप ड्रॉप करना चाहते हैं।

<server-username> - डेटाबेस का प्रयोक्ता नाम, जिसके पास डेटाबेस को छोड़ने का विशेषाधिकार है।

<server-user-password> - विशेष उपयोगकर्ता का पासवर्ड।

उदाहरण

डेटाबेस को ड्रॉप करने के दो तरीके हैं, एक वर्तमान में खुले डेटाबेस को गिराता है और दूसरा किसी विशेष नाम को प्रदान करके किसी डेटाबेस को छोड़ देता है।

इस उदाहरण में, हम 'डेमो' नाम के उसी डेटाबेस का उपयोग करेंगे जो हमने पहले के अध्याय में बनाया था। डेटाबेस को छोड़ने के लिए आप निम्न कमांड का उपयोग कर सकते हैंdemo

orientdb {db = demo}> DROP DATABASE

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

Database 'demo' deleted successfully

OR

डेटाबेस को छोड़ने के लिए आप अन्य कमांड का उपयोग कर सकते हैं।

orientdb> DROP DATABASE PLOCAL:/opt/orientdb/databases/demo admin admin

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

Database 'demo' deleted successfully

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

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

निम्न कथन सम्मिलित करें रिकॉर्ड आदेश का मूल सिंटैक्स है।

INSERT INTO [class:]<class>|cluster:<cluster>|index:<index> 
   [(<field>[,]*) VALUES (<expression>[,]*)[,]*]| 
   [SET <field> = <expression>|<sub-command>[,]*]| 
   [CONTENT {<JSON>}] 
   [RETURN <expression>]  
   [FROM <query>]

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

SET - मूल्य के साथ-साथ प्रत्येक क्षेत्र को परिभाषित करता है।

CONTENT- फील्ड मान सेट करने के लिए JSON डेटा को परिभाषित करता है। यह वैकल्पिक है।

RETURN- सम्मिलित किए गए रिकॉर्ड की संख्या के बजाय वापस जाने के लिए अभिव्यक्ति को परिभाषित करता है। सबसे आम उपयोग के मामले हैं -

  • @rid - नए रिकॉर्ड की रिकॉर्ड आईडी लौटाता है।

  • @this - पूरा नया रिकॉर्ड लौटाता है।

FROM - जहां आप रिकॉर्ड या परिणाम सेट सम्मिलित करना चाहते हैं।

उदाहरण

आइए हम निम्नलिखित क्षेत्रों और प्रकारों के साथ एक ग्राहक तालिका पर विचार करें।

अनु क्रमांक। कार्यक्षेत्र नाम प्रकार
1 ईद पूर्णांक
2 नाम तार
3 उम्र पूर्णांक

आप निम्न आदेशों को निष्पादित करके स्कीमा (तालिका) बना सकते हैं।

CREATE DATABASE PLOCAL:/opt/orientdb/databases/sales 
CREATE CLASS Customer 
CREATE PROPERTY Customer.id integer 
CREATE PROPERTY Customer.name String 
CREATE PROPERTY Customer.age integer

सभी आदेशों को निष्पादित करने के बाद, आपको आईडी, नाम और आयु क्षेत्रों के साथ तालिका का नाम ग्राहक मिलेगा। आप ग्राहक तालिका में चुनिंदा क्वेरी को निष्पादित करके तालिका की जांच कर सकते हैं।

ओरिएंटबीडी एक रिकॉर्ड सम्मिलित करने के लिए विभिन्न तरीके प्रदान करता है। नमूना रिकॉर्ड वाले निम्नलिखित ग्राहक तालिका पर विचार करें।

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

निम्न आदेश ग्राहक तालिका में पहला रिकॉर्ड सम्मिलित करने के लिए है।

INSERT INTO Customer (id, name, age) VALUES (01,'satish', 25)

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

Inserted record 'Customer#11:0{id:1,name:satish,age:25} v1' in 0.069000 sec(s).

निम्नलिखित आदेश ग्राहक तालिका में दूसरा रिकॉर्ड सम्मिलित करना है।

INSERT INTO Customer SET id = 02, name = 'krishna', age = 26

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

Inserted record 'Customer#11:1{id:2,age:26,name:krishna} v1' in 0.005000 sec(s).

निम्न आदेश ग्राहक तालिका में तीसरा रिकॉर्ड सम्मिलित करने के लिए है।

INSERT INTO Customer CONTENT {"id": "03", "name": "kiran", "age": "29"}

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

Inserted record 'Customer#11:2{id:3,name:kiran,age:29} v1' in 0.004000 sec(s).

निम्न आदेश ग्राहक तालिका में अगले दो रिकॉर्ड सम्मिलित करने के लिए है।

INSERT INTO Customer (id, name, age) VALUES (04,'javeed', 21), (05,'raja', 29)

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

Inserted record '[Customer#11:3{id:4,name:javeed,age:21} v1,
Customer#11:4{id:5,name:raja,age:29} v1]' in 0.007000 sec(s).

आप जांच सकते हैं कि ये सभी रिकॉर्ड निम्नलिखित कमांड को निष्पादित करके सम्मिलित किए गए हैं या नहीं।

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   
----+-----+--------+----+-------+----

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 
----+-----+--------+----+-------+----

Load Recordस्कीमा से एक विशेष रिकॉर्ड लोड करने के लिए उपयोग किया जाता है। लोड रिकॉर्ड रिकॉर्ड आईडी की मदद से रिकॉर्ड को लोड करेगा। इसके साथ प्रतिनिधित्व किया है@rid परिणाम में प्रतीक।

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

LOAD RECORD <record-id>

कहाँ पे <record-id> उस रिकॉर्ड की रिकॉर्ड आईडी को परिभाषित करता है जिसे आप लोड करना चाहते हैं।

यदि आप किसी विशेष रिकॉर्ड की रिकॉर्ड आईडी नहीं जानते हैं, तो आप टेबल के खिलाफ किसी भी क्वेरी को निष्पादित कर सकते हैं। रिजल्ट-सेट में आपको संबंधित रिकॉर्ड का रिकॉर्ड आईडी (@rid) मिलेगा।

उदाहरण

आइए हम उसी ग्राहक तालिका पर विचार करें जिसका उपयोग हमने पिछले अध्यायों में किया है।

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

रिकॉर्ड ID वाले रिकॉर्ड को पुनः प्राप्त करने के लिए निम्नलिखित क्वेरी का प्रयास करें @rid: #11:0

orientdb {db = demo}> LOAD RECORD #11:0

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

+---------------------------------------------------------------------------+ 
| Document - @class: Customer        @rid: #11:0           @version: 1      | 
+---------------------------------------------------------------------------+ 
|                     Name | Value                                          | 
+---------------------------------------------------------------------------+ 
|                       id | 1                                              | 
|                     name | satish                                         | 
|                      age | 25                                             | 
+---------------------------------------------------------------------------+

Reload Recordलोड रिकॉर्ड कमांड के समान भी काम करता है और इसका उपयोग स्कीमा से एक विशेष रिकॉर्ड लोड करने के लिए भी किया जाता है। लोड रिकॉर्ड रिकॉर्ड आईडी की मदद से रिकॉर्ड को लोड करेगा। इसके साथ प्रतिनिधित्व किया है@ridपरिणाम सेट में प्रतीक। मुख्य अंतर रीलोड रिकॉर्ड कैश को अनदेखा करता है जो तब उपयोगी होता है जब रिकॉर्ड बदलने के लिए बाहरी समवर्ती लेनदेन लागू किया जाता है। यह लेटेस्ट अपडेट देगा।

निम्नलिखित कथन RELOAD रिकॉर्ड कमांड का मूल सिंटैक्स है।

RELOAD RECORD <record-id>

कहाँ पे <record-id> उस रिकॉर्ड की रिकॉर्ड आईडी को परिभाषित करता है जिसे आप पुनः लोड करना चाहते हैं।

यदि आप किसी विशेष रिकॉर्ड की रिकॉर्ड आईडी नहीं जानते हैं, तो आप टेबल के खिलाफ किसी भी क्वेरी को निष्पादित कर सकते हैं। रिजल्ट-सेट में आपको संबंधित रिकॉर्ड का रिकॉर्ड आईडी (@rid) मिलेगा।

उदाहरण

आइए हम उसी ग्राहक तालिका पर विचार करें जिसका उपयोग हमने पिछले अध्याय में किया है।

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

रिकॉर्ड ID वाले रिकॉर्ड को पुनः प्राप्त करने के लिए निम्नलिखित क्वेरी का प्रयास करें @rid: #11:0

orientdb {db = demo}> LOAD RECORD #11:0

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

+---------------------------------------------------------------------------+ 
| Document - @class: Customer        @rid: #11:0           @version: 1      | 
+---------------------------------------------------------------------------+ 
|                     Name | Value                                          | 
+---------------------------------------------------------------------------+ 
|                       id | 1                                              | 
|                     name | satish                                         | 
|                      age | 25                                             | 
+---------------------------------------------------------------------------+

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

निम्न कथन निर्यात रिकॉर्ड कमांड का मूल सिंटैक्स है।

EXPORT RECORD <format>

कहाँ पे <Format> उस प्रारूप को परिभाषित करता है जिसे आप रिकॉर्ड प्राप्त करना चाहते हैं।

Note - निर्यात कमांड रिकॉर्ड आईडी के आधार पर लोड किए गए रिकॉर्ड को निर्यात करेगा।

उदाहरण

आइए हम उसी ग्राहक तालिका पर विचार करें जिसका उपयोग हमने पिछले अध्याय में किया है।

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

रिकॉर्ड ID वाले रिकॉर्ड को पुनः प्राप्त करने के लिए निम्नलिखित क्वेरी का प्रयास करें @rid: #11:0

orientdb {db = demo}> LOAD RECORD #11:0

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

+---------------------------------------------------------------------------+ 
| Document - @class: Customer        @rid: #11:0           @version: 1      | 
+---------------------------------------------------------------------------+ 
|                     Name | Value                                          | 
+---------------------------------------------------------------------------+ 
|                       id | 1                                              | 
|                     name | satish                                         | 
|                      age | 25                                             | 
+---------------------------------------------------------------------------+

JSON प्रारूप में रिकॉर्ड (# 11: 0) लोड करने के लिए वह निम्नलिखित क्वेरी का उपयोग करें।

orientdb {db = demo}> EXPORT RECORD json

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

{ 
   "@type": "d", 
      "@rid": "#11:0", 
   "@version": 1, 
   "@class": "Customer", 
      "id": 1, 
      "name": "satish", 
      "age": 25 
}

Update Recordकमांड का उपयोग किसी विशेष रिकॉर्ड के मान को संशोधित करने के लिए किया जाता है। विशिष्ट क्षेत्र मान को अद्यतन करने के लिए SET मूल कमांड है।

निम्न कथन अद्यतन कमांड का मूल सिंटैक्स है।

UPDATE <class>|cluster:<cluster>|<recordID> 
   [SET|INCREMENT|ADD|REMOVE|PUT <field-name> = <field-value>[,]*] |[CONTENT| MERGE <JSON>] 
   [UPSERT] 
   [RETURN <returning> [<returning-expression>]] 
   [WHERE <conditions>] 
   [LOCK default|record] 
   [LIMIT <max-records>] [TIMEOUT <timeout>]

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

SET - अद्यतन करने के लिए क्षेत्र को परिभाषित करता है।

INCREMENT - दिए गए मूल्य द्वारा निर्दिष्ट फ़ील्ड मान को बढ़ाता है।

ADD - संग्रह क्षेत्रों में नए आइटम जोड़ता है।

REMOVE - संग्रह क्षेत्र से एक आइटम निकालता है।

PUT - मानचित्र क्षेत्र में एक प्रविष्टि डालता है।

CONTENT - JSON दस्तावेज़ सामग्री के साथ रिकॉर्ड सामग्री को प्रतिस्थापित करता है।

MERGE - एक JSON दस्तावेज़ के साथ रिकॉर्ड सामग्री को जोड़ता है।

LOCK- निर्दिष्ट करता है कि लोड और अपडेट के बीच रिकॉर्ड कैसे लॉक करें। हमारे पास निर्दिष्ट करने के लिए दो विकल्प हैंDefault तथा Record

UPSERT- अगर यह मौजूद है या नहीं करता है तो एक नया रिकॉर्ड सम्मिलित करता है, एक रिकॉर्ड को अपडेट करता है। यह दो क्वेरी को निष्पादित करने के स्थान पर एक ही क्वेरी को निष्पादित करने में मदद करता है।

RETURN - रिकॉर्ड की संख्या के बजाय लौटने के लिए एक अभिव्यक्ति निर्दिष्ट करता है।

LIMIT - अद्यतन करने के लिए रिकॉर्ड की अधिकतम संख्या को परिभाषित करता है।

TIMEOUT - उस समय को परिभाषित करता है जिसे आप अपडेट करने की अनुमति देना चाहते हैं, इससे पहले कि वह इसे चलाए।

उदाहरण

आइए हम उसी ग्राहक तालिका पर विचार करें जिसका उपयोग हमने पिछले अध्याय में किया है।

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

ग्राहक 'राजा' की आयु को अद्यतन करने के लिए निम्नलिखित प्रश्न का प्रयास करें।

Orientdb {db = demo}> UPDATE Customer SET age = 28 WHERE name = 'Raja'

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

Updated 1 record(s) in 0.008000 sec(s).

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

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   |28   
----+-----+--------+----+-------+----

Truncate Record कमांड का उपयोग किसी विशेष रिकॉर्ड के मूल्यों को हटाने के लिए किया जाता है।

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

TRUNCATE RECORD <rid>*

कहाँ पे <rid>* रिकॉर्ड आईडी को इंगित करने के लिए छोटा करना। आप कई रिकॉर्ड्स को अलग करने के लिए अल्पविराम द्वारा अलग किए गए कई Rids का उपयोग कर सकते हैं। यह काटे गए रिकॉर्ड की संख्या लौटाता है।

उदाहरण

आइए हम उसी ग्राहक तालिका पर विचार करें जिसका उपयोग हमने पिछले अध्याय में किया है।

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

रिकॉर्ड आईडी # 11: 4 वाले रिकॉर्ड को छोटा करने के लिए निम्नलिखित क्वेरी का प्रयास करें।

Orientdb {db = demo}> TRUNCATE RECORD #11:4

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

Truncated 1 record(s) in 0.008000 sec(s).

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

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 
----+-----+--------+----+-------+----

Delete Record कमांड का उपयोग डेटाबेस से एक या अधिक रिकॉर्ड को पूरी तरह से हटाने के लिए किया जाता है।

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

DELETE FROM <Class>|cluster:<cluster>|index:<index> 
   [LOCK <default|record>] 
   [RETURN <returning>] 
   [WHERE <Condition>*] 
   [LIMIT <MaxRecords>] 
   [TIMEOUT <timeout>]

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

LOCK- निर्दिष्ट करता है कि लोड और अपडेट के बीच रिकॉर्ड कैसे लॉक करें। हमारे पास निर्दिष्ट करने के लिए दो विकल्प हैंDefault तथा Record

RETURN - रिकॉर्ड की संख्या के बजाय लौटने के लिए एक अभिव्यक्ति निर्दिष्ट करता है।

LIMIT - अद्यतन करने के लिए रिकॉर्ड की अधिकतम संख्या को परिभाषित करता है।

TIMEOUT - उस समय को परिभाषित करता है जिसे आप अपडेट करने की अनुमति देना चाहते हैं, इससे पहले कि वह इसे चलाए।

Note - ऊर्ध्वाधर या किनारों को हटाने के लिए DELETE का उपयोग न करें क्योंकि यह ग्राफ़ की अखंडता को प्रभावित करता है।

उदाहरण

आइए हम ग्राहक तालिका पर विचार करें।

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

आईडी = 4 वाले रिकॉर्ड को हटाने के लिए निम्नलिखित क्वेरी का प्रयास करें।

orientdb {db = demo}> DELETE FROM Customer WHERE id = 4

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

Delete 1 record(s) in 0.008000 sec(s).

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

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 
----+-----+--------+----+-------+----

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

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

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

CREATE CLASS <class> 
[EXTENDS <super-class>] 
[CLUSTER <cluster-id>*] 
[CLUSTERS <total-cluster-number>] 
[ABSTRACT]

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

<class> - उस वर्ग का नाम परिभाषित करता है जिसे आप बनाना चाहते हैं।

<super-class> - उस सुपर क्लास को परिभाषित करता है जिसे आप इस क्लास के साथ बढ़ाना चाहते हैं।

<total-cluster-number>- इस वर्ग में प्रयुक्त कुल समूहों की संख्या को परिभाषित करता है। डिफ़ॉल्ट 1 है।

ABSTARCT- परिभाषित करता है कि वर्ग अमूर्त है। यह वैकल्पिक है।

उदाहरण

जैसा कि चर्चा की गई है, कक्षा तालिका से संबंधित एक अवधारणा है। इसलिए यहां हम एक टेबल अकाउंट बनाएंगे। हालाँकि, क्लास बनाते समय हम खेतों को परिभाषित नहीं कर सकते, यानी OOPS प्रतिमान पर आधारित गुण।

निम्न आदेश एक खाता नाम से एक वर्ग बनाने के लिए है।

orientdb> CREATE CLASS Account

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

Class created successfully

क्लास बनाने के लिए आप निम्न कमांड का उपयोग कर सकते हैं Car जो कक्षा तक फैला हुआ है Vehicle

orientdb> CREATE CLASS Car EXTENDS Vehicle

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

Class created successfully

क्लास पर्सन को अमूर्त बनाने के लिए आप निम्न कमांड का उपयोग कर सकते हैं।

orientdb> CREATE CLASS Person ABSTRACT

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

Class created successfully

Note- गुण होने के बिना, वर्ग बेकार है और वास्तविक वस्तु का निर्माण करने में असमर्थ है। आगे के अध्यायों में, आप सीख सकते हैं कि किसी विशेष वर्ग के लिए गुण कैसे बनाएं।

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

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

ALTER CLASS <class> <attribute-name> <attribute-value>

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

<class> - वर्ग के नाम को परिभाषित करता है।

<attribute-name> - उस विशेषता को परिभाषित करता है जिसे आप बदलना चाहते हैं।

<attribute-value> - वह मान निर्धारित करता है जिसे आप विशेषता के लिए सेट करना चाहते हैं।

निम्न तालिका उन विशेषताओं की सूची को परिभाषित करती है जो ऑल्टर क्लास कमांड का समर्थन करती हैं।

गुण प्रकार विवरण
नाम तार वर्ग का नाम बदलता है।
संक्षिप्त नाम तार वर्ग के लिए एक छोटा नाम, (जो एक उपनाम है) को परिभाषित करता है। संक्षिप्त नाम असाइनमेंट को निकालने के लिए NULL का उपयोग करें।
सुपर क्लास तार वर्ग के लिए एक सुपर-क्लास को परिभाषित करता है। एक नया वर्ग जोड़ने के लिए, आप सिंटैक्स + <वर्ग> का उपयोग कर सकते हैं, इसका उपयोग हटाने के लिए - <वर्ग>।
बड़े आकार दशमलव संख्या ओवरसाइज़ फैक्टर को परिभाषित करता है।
ADDCLUSTER तार एक वर्ग को जोड़ता है। यदि क्लस्टर मौजूद नहीं है, तो यह एक भौतिक क्लस्टर बनाता है। वितरित सर्वर में रिकॉर्ड संग्रहीत करने के लिए एक वर्ग में क्लस्टर जोड़ना भी उपयोगी है।
REMOVECLUSTER तार एक वर्ग से एक क्लस्टर निकालता है। यह क्लस्टर को हटाता नहीं है, केवल इसे कक्षा से निकालता है।
सख्त मोड - सख्त मोड को सक्षम या अक्षम करता है। जब सख्त मोड में होता है, तो आप स्कीमा-फुल मोड में काम करते हैं और अगर वे क्लास की स्कीमा परिभाषा का हिस्सा हैं, तो एक रिकॉर्ड में नई प्रॉपर्टी नहीं जोड़ सकते।
CLUSTERSELECTION - नए रिकॉर्ड के लिए किस क्लस्टर का उपयोग करता है यह चुनने में चयन रणनीति को परिभाषित करता है।
कस्टम - कस्टम गुणों को परिभाषित करता है। प्रॉपर्टी के नाम और मान वाक्य और मान के बीच रिक्त स्थान के बिना सिंटैक्स <propertyname> = <value> का पालन करना चाहिए।
सार बूलियन वर्ग को एक अमूर्त वर्ग या विपरीत में परिवर्तित करता है।

उदाहरण

आइए हम कुछ उदाहरणों की कोशिश करें जो मौजूदा वर्ग की विशेषताओं को अपडेट या संशोधित करेंगे।

निम्न क्वेरी का उपयोग एक मौजूदा वर्ग 'कर्मचारी' के लिए एक सुपर-क्लास 'व्यक्ति' को परिभाषित करने के लिए किया जाता है।

orientdb> ALTER CLASS Employee SUPERCLASS Person

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

Class altered successfully

निम्न क्वेरी का उपयोग मौजूदा वर्ग 'कर्मचारी' के लिए एक सुपर-क्लास 'व्यक्ति' को जोड़ने के लिए किया जाता है।

orientdb> ALTER CLASS Employee SUPERCLASS +Person

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

Class altered successfully

Truncate classक्लास के हिस्से के रूप में परिभाषित क्लस्टर्स के सभी रिकॉर्ड को हटा देगा। OrientDB में, हर वर्ग का एक ही नाम के साथ एक संबद्ध क्लस्टर है। यदि आप वर्ग पदानुक्रम से सभी रिकॉर्ड भी निकालना चाहते हैं, तो आपको पॉलीमरॉफ़िक कीवर्ड का उपयोग करना होगा।

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

TRUNCATE CLASS <class> [ POLYMORPHIC ] [ UNSAFE ]

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

<class> - जिस वर्ग को आप छोटा करना चाहते हैं, उसे परिभाषित करता है।

POLYMORPHIC - परिभाषित करता है कि क्या कमांड भी पदानुक्रम को काटता है।

UNSAFE - कमांड बलों ट्रंकेशन को वर्टेक्स या एज क्लास पर परिभाषित करता है।

उदाहरण

एक वर्ग को छोटा करने के लिए निम्नलिखित क्वेरी Profile

orientdb> TRUNCATE CLASS Profile

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

Class truncated successfully

Drop Classकमांड स्कीमा से एक वर्ग निकालता है। ध्यान देना और एक सुसंगत स्कीमा बनाए रखना महत्वपूर्ण है। उदाहरण के लिए, उन कक्षाओं को हटाने से बचें जो दूसरों के सुपर-क्लास हैं। संबंधित क्लस्टर हटाया नहीं जाएगा।

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

DROP CLASS <class>

कक्षा नाम के साथ एक कक्षा छोड़ें।

उदाहरण

एक कर्मचारी को छोड़ने के लिए निम्न क्वेरी का प्रयास करें।

Orientdb> DROP CLASS Employee

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

Class dropped successfully

Clusterओरिएंटडीबी में एक महत्वपूर्ण अवधारणा है जिसका उपयोग रिकॉर्ड, दस्तावेज, या कोने को संग्रहीत करने के लिए किया जाता है। सरल शब्दों में, क्लस्टर एक ऐसी जगह है जहां रिकॉर्ड का एक समूह संग्रहीत किया जाता है। डिफ़ॉल्ट रूप से, OrientDB प्रति वर्ग एक क्लस्टर बनाएगा। एक वर्ग के सभी रिकॉर्ड एक ही क्लस्टर में संग्रहीत किए जाते हैं, जिसका वर्ग के समान नाम है। आप एक डेटाबेस में 32,767 (2 ^ 15-1) क्लस्टर बना सकते हैं।

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

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

CREATE CLUSTER <cluster> [ID <cluster-id>]

कहाँ पे <cluster> उस क्लस्टर का नाम परिभाषित करता है जिसे आप बनाना चाहते हैं और <cluster-id> उस संख्यात्मक आईडी को परिभाषित करता है जिसे आप क्लस्टर के लिए उपयोग करना चाहते हैं।

निम्न तालिका क्लस्टर चयन रणनीतियों की सूची प्रदान करती है।

अनु क्रमांक। रणनीति और विवरण
1

Default

वर्ग गुण डिफ़ॉल्ट ClusterId का उपयोग करके क्लस्टर का चयन करता है।

2

Round-robin

एक गोलाकार क्रम में अगले क्लस्टर का चयन करता है। यह एक बार पूरा होने के बाद पुनः आरंभ हो रहा है।

3

Balanced

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

उदाहरण

चलिए एक उदाहरण लेते हैं जिसका नाम है बिक्री नाम का क्लस्टर बनाना।

orientdb> CREATE CLUSTER sales

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

Cluster created correctly with id #12

Alter Clusterमौजूदा क्लस्टर पर विशेषताओं को अद्यतन करने के लिए कमांड है। इस अध्याय में आप जान सकते हैं कि किसी क्लस्टर की विशेषताओं को कैसे जोड़ा या संशोधित किया जा सकता है।

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

ALTER CLUSTER <cluster> <attribute-name> <attribute-value>

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

<cluster> - क्लस्टर नाम परिभाषित करता है।

<attribute-name> - उस विशेषता को परिभाषित करता है जिसे आप बदलना चाहते हैं।

<attribute-value> - इस विशेषता के लिए आप जो मूल्य निर्धारित करना चाहते हैं, उसे परिभाषित करता है।

निम्न सारणीबद्ध प्रारूप समर्थित विशेषताओं की सूची प्रदान करता है जिन्हें आप Alter क्लस्टर कमांड के साथ उपयोग कर सकते हैं।

नाम प्रकार विवरण
नाम तार क्लस्टर नाम बदलता है।
स्थिति तार क्लस्टर स्थिति को बदलता है। स्वीकृत मूल्य ONLINE और OFFLINE हैं। डिफ़ॉल्ट रूप से, क्लस्टर ऑनलाइन हैं।
COMPRESSION तार उपयोग करने के लिए संपीड़न प्रकार को परिभाषित करता है। अनुमत मूल्य NOTHING, SNAPPY, GZIP, और OCompressionFactory वर्ग में पंजीकृत कोई अन्य संपीड़न प्रकार हैं।
USE_WAL बूलियन परिभाषित करता है कि क्या यह जर्नल का उपयोग करता है जब ओरिएंटबीडी क्लस्टर के खिलाफ संचालित होता है
RECORD_GROW_FACTO आर पूर्णांक रिकॉर्ड निर्माण पर अधिक स्थान बचाने के लिए बढ़ते कारक को परिभाषित करता है। जब आप रिकॉर्ड को अतिरिक्त जानकारी के साथ अपडेट करते हैं तो आपको यह उपयोगी लग सकता है।
RECORD_OVERFLOW_GR OW_FACTOR पूर्णांक अद्यतन पर कारक को परिभाषित करता है। जब यह आकार सीमा तक पहुँच जाता है, तो अधिक स्थान पाने के लिए इस सेटिंग का उपयोग करता है, (कारक> 1)।
CONFLICTSTRATEGY तार उस रणनीति को परिभाषित करता है जो उस घटना में संघर्ष को संभालने के लिए उपयोग करता है जो ओरिएंटबीडी एमवीसीसी एक अद्यतन या एक पुराने रिकॉर्ड के खिलाफ निष्पादित ऑपरेशन हटाता है।

निम्न तालिका संघर्ष रणनीतियों की सूची प्रदान करती है।

अनु क्रमांक। रणनीति और विवरण
1

Version

जब संस्करण भिन्न होते हैं तो एक अपवाद को फेंक देता है। यह डिफ़ॉल्ट सेटिंग है।

2

Content

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

3

Automerge

परिवर्तनों को जोड़ता है।

उदाहरण

Alter क्लस्टर कमांड सीखने के लिए निम्न उदाहरण क्वेरीज़ आज़माएँ।

कर्मचारी से कर्मचारी के क्लस्टर का नाम बदलने के लिए निम्न आदेश निष्पादित करें।

orientdb {db = demo}> ALTER CLUSTER Employee NAME Employee2

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

Cluster updated successfully

क्लस्टर ID का उपयोग कर Employee2 से एक कर्मचारी का नाम बदलने के लिए निम्न आदेश निष्पादित करें।

orientdb {db = demo}> ALTER CLUSTER 12 NAME Employee

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

Cluster updated successfully

क्लस्टर विरोध रणनीति को ऑटोमैटर करने के लिए निम्न कमांड निष्पादित करें।

orientdb {db = demo}> ALTER CLUSTER V CONFICTSTRATEGY automerge

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

Cluster updated successfully

Truncate Cluster आदेश क्लस्टर के सभी रिकॉर्ड हटाता है।

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

TRUNCATE CLUSTER <cluster-name>

कहाँ पे <cluster-name> क्लस्टर का नाम है।

उदाहरण

बिक्री नामक क्लस्टर को छोटा करने के लिए निम्न क्वेरी का प्रयास करें।

Orientdb {db = demo}> TRUNCATE CLUSTER Profile

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

Cluster truncated successfully.

Drop Clusterकमांड क्लस्टर और उसके सभी संबंधित सामग्री को हटा देती है। यह ऑपरेशन स्थायी और रोलबैक है।

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

DROP CLUSTER <cluster-name>|<cluster-id>

कहाँ पे <cluster-name> उस क्लस्टर का नाम परिभाषित करता है जिसे आप निकालना चाहते हैं और <cluster-id> उस क्लस्टर की आईडी को परिभाषित करता है जिसे आप निकालना चाहते हैं।

उदाहरण

विक्रय क्लस्टर को निकालने के लिए निम्न आदेश का प्रयास करें।

orientdb> DROP CLUSTER Sales

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

Cluster dropped successfully

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

निम्न कथन क्रिएट प्रॉपर्टी कमांड का मूल सिंटैक्स है।

CREATE PROPERTY <class-name>.<property-name> <property-type> [<linked-type>][ <linked-class>]

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

<class-name> - आप जिस वर्ग में संपत्ति बनाना चाहते हैं, उसे परिभाषित करता है।

<property-name> - संपत्ति का तार्किक नाम परिभाषित करता है।

<property-type> - आपके द्वारा बनाई गई संपत्ति के प्रकार को परिभाषित करता है।

<linked-type> - कंटेनर प्रकार को परिभाषित करता है, कंटेनर संपत्ति प्रकार में उपयोग किया जाता है।

<linked-class> - कंटेनर क्लास को परिभाषित करता है, जिसका उपयोग कंटेनर प्रॉपर्टी के प्रकार में किया जाता है।

निम्न तालिका संपत्ति के लिए डेटा प्रकार प्रदान करती है ताकि ओरिएंटबीडी को स्टोर करने के लिए डेटा का प्रकार पता हो।

बूलियन पूर्णांक कम लंबा
फ्लोट दिनांक तार एम्बेडेड
संपर्क बाइट बायनरी दोहरा

इनके अतिरिक्त कई अन्य प्रकार के गुण हैं जो कंटेनरों के रूप में काम करते हैं।

EMBEDDEDLIST EMBEDDEDSET EMBEDDEDMAP
LINKLIST LINKSET LINKMAP

उदाहरण

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

orientdb> CREATE PROPERTY Employee.name STRING

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

Property created successfully with id = 1

Alter Propertyएक विशेष वर्ग की संपत्ति को संशोधित करने या अद्यतन करने के लिए प्रयोग किया जाने वाला कमांड है। संपत्ति को बदलने का मतलब है एक तालिका के क्षेत्रों को संशोधित करना। इस अध्याय में, आप जान सकते हैं कि संपत्ति को कैसे अपडेट किया जाए।

निम्नलिखित कथन ऑल्टर प्रॉपर्टी कमांड का मूल सिंटैक्स है।

ALTER PROPERTY <class>.<property> <attribute-name> <attribute-value>

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

<class> - जिस वर्ग की संपत्ति है, उसे परिभाषित करता है।

<property> - उस संपत्ति को परिभाषित करता है जिसे आप अपडेट करना चाहते हैं।

<attribute-name> - उस संपत्ति की विशेषता को परिभाषित करता है जिसे आप अपडेट करना चाहते हैं।

<attribute-value> - वह मान निर्धारित करता है जिसे आप विशेषता पर सेट करना चाहते हैं।

निम्न तालिका संपत्ति को बदलने के लिए विशेषताओं की सूची को परिभाषित करती है।

गुण प्रकार विवरण
LINKEDCLASS तार लिंक किए गए वर्ग नाम को परिभाषित करता है। मौजूदा मान को निकालने के लिए NULL का उपयोग करें।
LINKEDTYPE तार लिंक प्रकार को परिभाषित करता है। मौजूदा मान को निकालने के लिए NULL का उपयोग करें।
मिनट पूर्णांक एक बाधा के रूप में न्यूनतम मूल्य को परिभाषित करता है। मौजूदा बाधा को दूर करने के लिए NULL का उपयोग करें।
अनिवार्य बूलियन परिभाषित करता है कि संपत्ति को एक मूल्य की आवश्यकता है या नहीं।
मैक्स पूर्णांक एक बाधा के रूप में अधिकतम मूल्य को परिभाषित करता है। मौजूदा बाधा को दूर करने के लिए NULL का उपयोग करें।
नाम तार संपत्ति के नाम को परिभाषित करता है।
शून्य नहीं बूलियन परिभाषित करता है कि क्या संपत्ति का एक पूर्ण मूल्य हो सकता है।
regex तार एक नियमित अभिव्यक्ति को बाधा के रूप में परिभाषित करता है। मौजूदा बाधा को दूर करने के लिए NULL का उपयोग करें।
प्रकार तार एक संपत्ति प्रकार को परिभाषित करता है।
मुक़ाबला करना तार सेट्स परिभाषित तुलना रणनीतियों में से एक से टकराते हैं। डिफ़ॉल्ट रूप से, यह केस-संवेदी (सीएस) पर सेट है। आप इसे केस-इनसेंसिटिव (ci) में भी सेट कर सकते हैं।
सिफ़ पढ़िये बूलियन परिभाषित करता है कि क्या संपत्ति का मूल्य अपरिवर्तनीय है। यही है, अगर पहले असाइनमेंट के बाद इसे बदलना संभव है। निर्माण पर अपरिवर्तनीय मूल्य रखने के लिए DEFAULT के साथ उपयोग करें।
कस्टम तार कस्टम गुणों को परिभाषित करता है। कस्टम गुणों का सिंटैक्स <custom-name> = <custom-value> है, जैसे स्टीरियोटाइप = आइकन।
चूक   डिफ़ॉल्ट मान या फ़ंक्शन को परिभाषित करता है।

Note - अगर आप NAME या TYPE बदल रहे हैं, तो यह कमांड डेटा की मात्रा के आधार पर अपडेट होने में कुछ समय लेगी।

उदाहरण

कुछ प्रश्नों को आज़माएं, जो ऑल्टर प्रॉपर्टी को समझने के लिए नीचे दिए गए हैं।

क्लास कस्टमर में प्रॉपर्टी का नाम 'उम्र' से 'जन्म' तक बदलने के लिए निम्न क्वेरी निष्पादित करें।

orinetdb {db = demo}> ALTER PROPERTY Customer.age NAME born

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

Property altered successfully

निम्न क्वेरी को 'ग्राहक' की अनिवार्य संपत्ति के रूप में 'नाम' बनाने के लिए निष्पादित करें।

orientdb {db = demo}> ALTER PROPERTY Customer.name MANDATORY TRUE

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

Property altered successfully

Drop propertyआदेश स्कीमा से संपत्ति निकालता है। यह संपत्ति के मूल्यों को रिकॉर्ड से नहीं हटाता है, यह सिर्फ स्कीमा को बदलता है।

निम्न कथन ड्रॉप प्रॉपर्टी कमांड का मूल सिंटैक्स है।

DROP PROPERTY <class>.<property> [FORCE]

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

<class> - उस वर्ग को परिभाषित करता है जहां संपत्ति मौजूद है।

<property> - उस संपत्ति को परिभाषित करता है जिसे आप निकालना चाहते हैं।

[Force] - यदि संपत्ति पर एक या एक से अधिक सूचकांक परिभाषित किए गए हैं।

उदाहरण

वर्ग 'ग्राहक' से 'आयु' की संपत्ति को हटाने के लिए निम्नलिखित आदेश का प्रयास करें।

orientdb> DROP PROPERTY Customer.age

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

Property dropped successfully

OrientDB डेटाबेस न केवल एक दस्तावेज़ डेटाबेस है, बल्कि एक ग्राफ़ डेटाबेस भी है। वर्टेक्स और एज जैसी नई अवधारणाओं का उपयोग ग्राफ के रूप में डेटा को स्टोर करने के लिए किया जाता है। यह कोने पर बहुरूपता को लागू करता है। वर्टेक्स के लिए आधार वर्ग वी है।

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

निम्न कथन क्रिएट वर्टेक्स कमांड का मूल सिंटैक्स है।

CREATE VERTEX [<class>] [CLUSTER <cluster>] [SET <field> = <expression>[,]*]

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

<class> - वर्ग को परिभाषित करता है, जिसमें शीर्षबिंदु है।

<cluster> - क्लस्टर को परिभाषित करता है जिसमें यह शीर्ष को संग्रहीत करता है।

<field> - उस क्षेत्र को परिभाषित करता है जिसे आप सेट करना चाहते हैं।

<expression> - क्षेत्र के लिए निर्धारित एक्सप्रेस को परिभाषित करता है।

उदाहरण

वर्टेक्स कैसे बनाएं, यह समझने के लिए निम्न उदाहरण को आज़माएँ।

आधार नाम के बिना एक शीर्ष बनाने के लिए निम्नलिखित क्वेरी निष्पादित करें और आधार वर्ग V पर।

orientdb> CREATE VERTEX

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

Created vertex 'V#9:0 v1' in 0.118000 sec(s)

V1 नामक एक नया वर्टेक्स क्लास बनाने के लिए निम्न क्वेरी निष्पादित करें, फिर उस क्लास में वर्टेक्स बनाएं।

orientdb> CREATE CLASS V1 EXTENDS V 
orientdb> CREATE VERTEX V1

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

Created vertex 'V1#14:0 v1' in 0.004000 sec(s)

V1 नाम के वर्ग का एक नया शीर्ष बनाने के लिए निम्नलिखित क्वेरी निष्पादित करें, ब्रांड = 'मारुति' और नाम = 'स्विफ्ट' जैसे गुणों को परिभाषित करते हुए।

orientdb> CREATE VERTEX V1 SET brand = 'maruti', name = 'swift'

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

Created vertex 'V1#14:1{brand:maruti,name:swift} v1' in 0.004000 sec(s)

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

निम्नलिखित कथन मूव वर्टेक्स कमांड का मूल सिंटैक्स है।

MOVE VERTEX <source> TO <destination> 
[SET [<field>=<value>]* [,]] 
[MERGE <JSON>] 
[BATCH <batch-size>]

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

<source>- उस शीर्ष को परिभाषित करता है जिसे आप स्थानांतरित करना चाहते हैं। यह एक विशेष वर्टेक्स की रिकॉर्ड आईडी या कोने के लिए रिकॉर्ड आईडी को स्वीकार करता है।

<destination>- परिभाषित करें कि आप शीर्ष को कहां ले जाना चाहते हैं। यह गंतव्य के रूप में वर्ग या क्लस्टर का समर्थन करता है।

SET - मानों को खेतों में सेट करता है।

MERGE - मान को JSON के माध्यम से फ़ील्ड में सेट करता है।

BATCH - बैच आकार को परिभाषित करता है।

Note- यह कमांड सभी कनेक्टेड किनारों को अपडेट करता है, लेकिन लिंक नहीं। ग्राफ एपीआई का उपयोग करते समय, कोने से जुड़े किनारे का उपयोग करने की सिफारिश की जाती है।

उदाहरण

शीर्षकों को स्थानांतरित करने का तरीका जानने के लिए निम्न उदाहरणों को आज़माएँ।

एक एकल शीर्ष को स्थानांतरित करने के लिए निम्न क्वेरी निष्पादित करें रिकॉर्ड ID # 11: 2 अपनी वर्तमान स्थिति से वर्ग कर्मचारी के लिए।

orientdb> MOVE VERTEX #11:2 TO CLASS:Employee

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

Move vertex command executed with result '[{old:#11:2, new:#13:0}]' in 0.022000 sec(s)

वर्ग 'ग्राहक' से वर्ग 'कर्मचारी' तक कोने के सेट को स्थानांतरित करने के लिए निम्नलिखित क्वेरी को निष्पादित करें।

orientdb> MOVE VERTEX (SELECT FROM Customer) TO CLASS:Employee

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

Move vertex command executed with result '[{old:#11:0, 
new:#13:1},{old:#11:1, new:#13:2},{old:#11:2, new:#13:3}]' in 0.011000 sec(s)

Delete Vertexकमांड का उपयोग डेटाबेस से वर्टिस निकालने के लिए किया जाता है। हटाते समय, यह किनारों के साथ स्थिरता की जांच करता है और हटाता है और हटाए गए शीर्ष पर सभी क्रॉस-रेफरेंस (किनारों के साथ) को हटा देता है।

निम्नलिखित कथन डिलीट वर्टेक्स कमांड का मूल सिंटैक्स है।

DELETE VERTEX <vertex> [WHERE <conditions>] 
[LIMIT <MaxRecords>>] [BATCH <batch-size>]

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

<vertex> - अपनी कक्षा, रिकॉर्ड आईडी, या उप-क्वेरी के माध्यम से उस शीर्ष को परिभाषित करता है जिसे आप निकालना चाहते हैं।

WHERE - यह निर्धारित करने के लिए स्थिति को फ़िल्टर करता है कि कौन सा कमांड हटाता है।

LIMIT - निकाले जाने वाले रिकॉर्ड की अधिकतम संख्या को परिभाषित करता है।

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

उदाहरण

एकल शीर्ष या एकाधिक शीर्षकों को हटाने का तरीका जानने के लिए निम्न कमांड का प्रयास करें।

'# 14: 1' शीर्ष को हटाने के लिए निम्न आदेश निष्पादित करें।

orientdb> DELETE VERTEX #14:1

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

Delete record(s) '1' in 0.005000 sec(s)

निम्न आदेश निष्पादित करें ''।

orientdb> DELETE VERTEX Customer WHERE isSpam = TRUE

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

Delete record(s) '3' in 0.005000 sec(s)

ओरिएंटडीबी में, अवधारणा Edgeकुछ गुणों की मदद से कोने के बीच संबंध की तरह काम करता है। किनारों और कोने एक ग्राफ डेटाबेस के मुख्य घटक हैं। यह किनारों पर बहुरूपता को लागू करता है। एज के लिए बेस क्लास ई है। किनारों को लागू करते समय, यदि स्रोत या गंतव्य कोने गायब हैं या मौजूद नहीं हैं, तो लेन-देन रोलबैक होगा।

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

CREATE EDGE <class> [CLUSTER <cluster>] FROM <rid>|(<query>)|[<rid>]* TO <rid>|(<query>)|[<rid>]* 
     [SET <field> = <expression>[,]*]|CONTENT {<JSON>} 
     [RETRY <retry> [WAIT <pauseBetweenRetriesInMs]] [BATCH <batch-size>]

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

<class> - किनारे के लिए वर्ग का नाम परिभाषित करता है।

<cluster> - उस क्लस्टर को परिभाषित करता है जिसमें आप किनारे को स्टोर करना चाहते हैं।

JSON - रिकॉर्ड के रूप में सेट करने के लिए JSON सामग्री प्रदान करता है।

RETRY - संघर्ष की स्थिति में प्रयास करने के लिए रिट्रीट की संख्या को परिभाषित करता है।

WAIT - मिलीसेकंड में रिट्रीट के बीच देरी का समय निर्धारित करता है।

BATCH - परिभाषित करता है कि क्या यह कमांड को छोटे ब्लॉक और बैच के आकार में तोड़ देता है।

उदाहरण

दो कोने # 9: 0 और # 14: 0 के बीच बढ़त E बनाने के लिए निम्नलिखित क्वेरी निष्पादित करें।

orientdb> CREATE EDGE FROM #11:4 TO #13:2

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

Created edge '[e[#10:0][#9:0->#14:0]]' in 0.012000 sec(s)

नया किनारा प्रकार और नए प्रकार के किनारे बनाने के लिए निम्न क्वेरी निष्पादित करें।

orientdb> CREATE CLASS E1 EXTENDS E 
orientdb> CREATE EDGE E1 FROM #10:3 TO #11:4

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

Created edge '[e[#10:1][#10:3->#11:4]]' in 0.011000 sec(s)

Update edgeवर्तमान डेटाबेस में एज रिकॉर्ड को अपडेट करने के लिए कमांड का उपयोग किया जाता है। यह उस स्थिति में वास्तविक अद्यतन आदेश के बराबर है, जब आप अद्यतन करते हैं, तो उस स्थिति में ग्राफ़ के साथ संगतता बनाए रखने और बनाए रखने के अलावाout तथा in गुण।

निम्न कथन अद्यतन एज कमांड का मूल सिंटैक्स है।

UPDATE EDGE <edge>  
   [SET|INCREMENT|ADD|REMOVE|PUT <field-name> = <field-value> [,]*]|[CONTENT|MERGE <JSON>] 
   [RETURN <returning> [<returning-expression>]] 
   [WHERE <conditions>] 
   [LOCK default|record] 
   [LIMIT <max-records>] [TIMEOUT <timeout>]

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

<edge>- उस किनारे को परिभाषित करें जिसे आप अपडेट करना चाहते हैं। आप चुन सकते हैंClass कक्षा द्वारा अद्यतन किए गए किनारों, Cluster क्लस्टर उपसर्ग का उपयोग करके किनारों को अद्यतन करता है, या Record ID कि रिकॉर्ड आईडी द्वारा किनारों को अद्यतन करना।

SET - दिए गए मूल्यों के लिए क्षेत्र को अद्यतन करता है।

INCREMENT - मूल्य द्वारा दिए गए क्षेत्र में वृद्धि।

ADD - खेतों के संग्रह में जोड़ने के लिए एक आइटम को परिभाषित करता है।

REMOVE - खेतों के संग्रह से हटाने के लिए एक आइटम को परिभाषित करता है।

PUT - मानचित्र क्षेत्रों में डालने के लिए एक प्रविष्टि को परिभाषित करता है।

RETURN - अपडेट को चलाने के बाद आप जिस एक्सप्रेशन को वापस करना चाहते हैं, उसे परिभाषित करता है।

WHERE - फिल्टर की स्थिति को परिभाषित करता है।

LOCK - परिभाषित करता है कि कैसे लोड और अपडेट के बीच रिकॉर्ड लॉक होता है।

LIMIT - रिकॉर्ड की अधिकतम संख्या को परिभाषित करता है।

उदाहरण

आइए एक व्यक्ति के वर्ग में 'पता' नाम के किनारे को अपडेट करने के एक उदाहरण पर विचार करें, जिसमें पता क्रमांक क्रमांक आईडी = 001 है, और व्यक्ति का नाम = कृष्ण है।

orientdb> UPDATE EDGE address SET out = (SELECT FROM Address WHERE areaID = 001) 
WHERE name = 'krishna'

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

Updated edge '[address[#10:3][#11:3->#14:2]]' in 0.012000 sec(s)

Delete edgeडेटाबेस को हटाने के लिए कमांड का उपयोग किया जाता है। यह डिलीट कमांड के बराबर है, जिसमें 'इन' और 'आउट' वर्टेक्स प्रॉपर्टीज से सभी क्रॉस-रेफरेंस को हटाकर वर्टिस के साथ कंसिस्टेंसी को बनाए रखने के साथ-साथ जोड़ दिया गया है।

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

DELETE EDGE  
   ( <rid> 
      | 
      [<rid> (, <rid>)*] 
      | 
      ( [ FROM (<rid> | <select_statement> ) ] [ TO ( <rid> | <select_statement> ) ] ) 
      | 
      [<class>]  
   ( 
      [WHERE <conditions>] 
      [LIMIT <MaxRecords>]  
      [BATCH <batch-size>]
   ))

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

FROM - नष्ट करने के लिए किनारे के शुरुआती बिंदु शीर्ष को परिभाषित करता है।

To - हटाने के लिए किनारे के अंतिम बिंदु शीर्ष को परिभाषित करता है।

WHERE - छानने की स्थिति को परिभाषित करता है।

LIMIT - हटाने के लिए किनारों की अधिकतम संख्या को परिभाषित करता है।

BATCH - ऑपरेशन के लिए ब्लॉक आकार को परिभाषित करता है।

उदाहरण

किनारों को हटाने के तरीके जानने के लिए निम्नलिखित उदाहरणों को आज़माएँ।

दो कोने (# 11: 2, # 11: 10) के बीच के किनारे को हटाने के लिए निम्न क्वेरी निष्पादित करें। लेकिन एक मौका हो सकता है जो दो कोने के बीच एक या एक से अधिक किनारों पर मौजूद हो सकता है। ताकि हम उचित कार्यक्षमता के लिए दिनांक संपत्ति का उपयोग कर रहे हैं। यह क्वेरी उन किनारों को हटा देगी जो '2015-01-15' और बादमें।

orientdb {db = demo}> DELETE EDGE FROM #11:2 TO #11:10 WHERE date >= "2012-01-15"

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

Delete record(s) '2' in 0.00200 sec(s)

'# 11: 5' से शुरू होने वाले किनारों को हटाने के लिए निम्नलिखित क्वेरी को '# 11: 10' के शीर्ष पर रखें और जो 'वर्ग = ग्राहक' से संबंधित हों।

orientdb {db = demo}> DELETE EDGE FROM #11:5 TO #11:10 WHERE @class = 'Customer'

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

Delete record(s) '2' in 0.00200 sec(s)

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

ग्राफ़ फ़ंक्शंस

अनु क्रमांक। समारोह का नाम और विवरण
1

Out():

वर्टेक्स के रूप में वर्तमान रिकॉर्ड से शुरू होने वाले आसन्न आउटगोइंग हो जाता है।

Syntax - बाहर ([<लेबल -1>] [, <लेबल- n>] *)

2

In():

वर्टेक्स के रूप में वर्तमान रिकॉर्ड से शुरू होने वाले आसन्न आवृत्तियों को प्राप्त करता है।

Syntax - ([<लेबल -1>] [, <लेबल-एन>] *) में

3

Both():

वर्टेक्स के रूप में वर्तमान रिकॉर्ड से शुरू होने वाले आसन्न आउटगोइंग और इनकमिंग वर्टिस हो जाता है।

Syntax - दोनों ([<लेबल 1>] [, <लेबल-एन>] *)

4

outE():

वर्टेक्स के रूप में वर्तमान रिकॉर्ड से शुरू होने वाले आसन्न आउटगोइंग किनारों को प्राप्त करता है।

Syntax - आउट ([<लेबल 1>] [, <लेबल-एन>] *)

5

inE():

वर्सेटेक्स के रूप में वर्तमान रिकॉर्ड से शुरू होने वाले आसन्न किनारों को प्राप्त करता है।

Syntax - इन ([<लेबल 1>] [, <लेबल-एन>] *)

6

bothE():

निकटवर्ती आउटगोइंग और आने वाले किनारों को वर्टेक्स के रूप में वर्तमान रिकॉर्ड से शुरू होता है।

Syntax - दोनों ([<लेबल 1>] [, <लेबल- n>] *)

7

outV():

वर्तमान रिकॉर्ड से शुरू होने वाले आउटगोइंग वर्ट्स को एज के रूप में प्राप्त करता है।

Syntax - outV ()

8

inV():

वर्तमान रिकॉर्ड से आने वाले कोने को एज के रूप में प्राप्त करें।

Syntax - inV ()

9

traversedElement():

ट्रैवर्स कमांड में ट्रैवर्स किए गए तत्व को लौटाता है।

Syntax - traversedElement (<इंडेक्स> [, <आइटम>])

10

traversedVertex():

ट्रैवर्स कमांड में ट्रैवर्स किए गए शीर्ष (एस) को लौटाएं।

Syntax - traversedVertex (<इंडेक्स> [, <आइटम>])

1 1

traversedEdge():

ट्रैवर्स कमांड में ट्रैवर्स किए गए किनारे (रिटर्न) को लौटाता है।

Syntax - ट्रैवर्सडेज (<सूचकांक> [, <आइटम>])

12

shortestPath():

दो कोने के बीच सबसे छोटा रास्ता देता है। दिशा OUT (डिफ़ॉल्ट), IN या BOTH हो सकती है।

Synatx - shortestPath (<sourceVertex>, <गंतव्य स्थान>> [, <दिशा> [, <edgeClassName>]]]

13

dijkstra():

दिज्क्स्ट्रा एल्गोरिथ्म का उपयोग करते हुए दो कोने के बीच सबसे सस्ता रास्ता देता है।

Syntax - दिज्क्स्त्र (<sourceVertex>, <गंतव्य स्थान>>, <वेटएडफ्लैडनाम> [, <दिशा>])

निम्नलिखित प्रश्नों के साथ कुछ ग्राफ़ फ़ंक्शंस आज़माएं।

सभी वाहन वर्टिकल से सभी आउटगोइंग वर्सेट्स प्राप्त करने के लिए निम्न क्वेरी निष्पादित करें।

orientdb {db = demo}>SELECT out() from Vehicle

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

---+----------+--------- 
 # | @class   | out 
---+----------+--------- 
 0 | Vehicle  | #11:2 
 1 | Vehicle  | #13:1 
 2 | Vehicle  | #13:4 
---+----------+---------

शीर्ष # 11: 3 से आने वाले और बाहर जाने वाले दोनों को प्राप्त करने के लिए निम्नलिखित क्वेरी को निष्पादित करें।

orientdb {db = demo}>SELECT both() FROM #11:3

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

---+----------+--------+------- 
 # | @class   | out    | in  
---+----------+--------+------- 
 0 | Vehicle  | #13:2  | #10:2   
 ---+----------+-------+-------

गणित के कार्य

अनु क्रमांक। समारोह का नाम और विवरण
1

eval():

उद्धरण (या दोहरे उद्धरण) के बीच की अभिव्यक्ति का मूल्यांकन करता है।

Syntax - eval ('<अभिव्यक्ति>')

2

min():

न्यूनतम मान लौटाता है। यदि एक से अधिक पैरामीटर के साथ लागू किया जाता है, तो यह सभी तर्कों के बीच न्यूनतम तर्क मूल्य देता है।

Syntax - मिनट (<फ़ील्ड> [, <फ़ील्ड-एन>] *)

3

max():

अधिकतम मान लौटाता है। यदि एक से अधिक पैरामीटर के साथ लागू किया जाता है, तो सभी तर्कों के बीच अधिकतम मान लौटाता है।

Syntax - अधिकतम (<फ़ील्ड> [, <फ़ील्ड-एन>] *)

4

sum()

लौटे सभी मानों का योग।

Syntax - योग (<फ़ील्ड>)

5

abs():

निरपेक्ष मान लौटाता है। यह Integer, Long, Short, Double, Float, BigInteger, BigDecimal, null के साथ काम करता है।

Syntax - एब्स (<फ़ील्ड>)

6

avg():

औसत मान लौटाता है।

Syntax - अवग (<फ़ील्ड>)

7

count():

क्वेरी स्थिति से मेल खाने वाले रिकॉर्ड को गिनता है। यदि फ़ील्ड के रूप में * का उपयोग नहीं किया जाता है, तो रिकॉर्ड केवल तभी गिना जाएगा यदि सामग्री शून्य नहीं है।

Syntax - गिनती (<फ़ील्ड>)

8

mode():

वह मान लौटाता है जो सबसे बड़ी आवृत्ति के साथ होता है। गणना में नल की अनदेखी की जाती है।

Syntax - मोड (<फ़ील्ड>)

9

median():

मानों को क्रमबद्ध करने के बाद मध्य मान या एक प्रक्षेपित मान लौटाता है जो मध्य मान का प्रतिनिधित्व करता है। गणना में नल की अनदेखी की जाती है।

Syntax माध्यिका (<क्षेत्र>)

10

percentile():

Nth प्रतिशताइल देता है। गणना में नल की अनदेखी की जाती है।

Syntax - प्रतिशतक (<फ़ील्ड> [, <quantile-n>] *)

1 1

variance()

मध्य विचरण लौटाता है: औसत से चुकता अंतर का औसत।

Syntax - विचरण (<फ़ील्ड>)

12

stddev()

मानक विचलन लौटाता है: मूल्यों को कैसे फैलाना है, इसका माप। गणना में नल की अनदेखी की जाती है।

Syntax - stddev (<फ़ील्ड>)

निम्नलिखित प्रश्नों का उपयोग करके कुछ गणित कार्यों की कोशिश करें।

सभी कर्मचारियों के वेतन का योग प्राप्त करने के लिए निम्नलिखित प्रश्न को निष्पादित करें।

orientdb {db = demo}>SELECT SUM(salary) FROM Employee

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

---+----------+--------- 
 # | @CLASS   | sum 
---+----------+--------- 
 0 | null     | 150000 
---+----------+---------

सभी कर्मचारियों का औसत वेतन पाने के लिए निम्नलिखित क्वेरी का निष्पादन करें।

orientdb {db = demo}>SELECT avg(salary) FROM Employee

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

---+----------+--------- 
 # | @CLASS   | avg 
---+----------+--------- 
 0 | null     | 25 
---+----------+---------

संग्रह कार्य

अनु क्रमांक। समारोह का नाम और विवरण
1

set():

एक सेट के लिए एक मूल्य जोड़ता है। यदि मान एक संग्रह है, तो इसे सेट के साथ मिला दिया जाता है, अन्यथा <value> जोड़ा जाता है।

Syntax - सेट (<फ़ील्ड>)

2

map():

पहली बार जब नक्शा बनाया जाता है, तो एक मान को जोड़ता है। यदि <value> एक मानचित्र है, तो इसे मानचित्र के साथ मिला दिया जाता है, अन्यथा जोड़ी <key> और <value> को नई प्रविष्टि के रूप में मानचित्र में जोड़ा जाता है।

Syntax - नक्शा (<कुंजी>, <मूल्य>)

3

ist():

पहली बार सूची बनाने के लिए मूल्य जोड़ता है। यदि <value> एक संग्रह है, तो इसे सूची में मिला दिया जाता है, अन्यथा <value> को सूची में जोड़ा जाता है।

Syntax - सूची (<फ़ील्ड>)

4

difference():

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

Syntax - अंतर (<फ़ील्ड> [, <फ़ील्ड-एन>] *)

5

first():

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

Syntax - पहला (<फ़ील्ड>)

6

intersect():

कुल या इनलाइन के रूप में काम करता है। यदि केवल एक तर्क पारित किया जाता है, तो एकत्र करता है, अन्यथा निष्पादित करता है, और वापस लौटाता है, मापदंडों के रूप में प्राप्त संग्रह का साक्षात्कार।

Syntax - प्रतिच्छेदन (<फ़ील्ड> [, <फ़ील्ड-एन>] *)

7

distinct():

तर्क के रूप में आपके द्वारा निर्दिष्ट फ़ील्ड के आधार पर केवल अनन्य डेटा प्रविष्टियाँ प्राप्त करता है। मानक SQL DISTINCT की तुलना में मुख्य अंतर यह है कि OrientDB के साथ, कोष्ठक और केवल एक क्षेत्र के साथ एक फ़ंक्शन निर्दिष्ट किया जा सकता है।

Syntax - अलग (<फ़ील्ड>)

8

expand():

इस फ़ंक्शन के दो अर्थ हैं

  • जब एक संग्रह क्षेत्र पर उपयोग किया जाता है, तो यह क्षेत्र में संग्रह को खोल देता है और परिणाम के रूप में उपयोग करता है।

  • जब एक लिंक (RID) फ़ील्ड पर उपयोग किया जाता है, तो यह उस लिंक द्वारा इंगित किए गए दस्तावेज़ को विस्तारित करता है।

Syntax - विस्तार (<फ़ील्ड>)

9

unionall():

कुल या इनलाइन के रूप में काम करता है। यदि केवल एक तर्क पारित किया जाता है, तो एकत्र करता है, अन्यथा मापदंडों के रूप में प्राप्त सभी संग्रहों का एक संघ निष्पादित करता है और वापस करता है। संग्रह मूल्यों के साथ भी काम करता है।

Syntax - संघाल (<क्षेत्र> [, <क्षेत्र-एन>] *)

10

flatten():

फ़ील्ड में संग्रह को निकालता है और परिणाम के रूप में उपयोग करता है। इसके बजाय इसका उपयोग () का विस्तार किया गया है।

Syntax - समतल (<फ़ील्ड>)

1 1

last():

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

Syntax - अंतिम (<फ़ील्ड>)

12

symmetricDifference():

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

Syntax - सममितीय संदर्भ (<फ़ील्ड> [, <फ़ील्ड-एन>] *)

निम्नलिखित प्रश्नों का उपयोग करके कुछ संग्रह कार्य करने का प्रयास करें।

कक्षा 9 वीं को पढ़ाने वाले शिक्षकों का एक सेट प्राप्त करने के लिए निम्नलिखित क्वेरी को निष्पादित करें।

orientdb {db = demo}>SELECT ID, set(teacher.id) AS teacherID from classess where class_id = 9

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

---+----------+--------+-------------------------- 
 # | @CLASS   | id     | TeacherID 
---+----------+--------+-------------------------- 
 0 | null     | 9     |   1201, 1202, 1205, 1208 
---+----------+-------+---------------------------

विविध कार्य

अनु क्रमांक। समारोह का नाम और विवरण
1

date():

किसी स्ट्रिंग को स्वरूपित करने वाली दिनांक देता है। <date-as-string> स्ट्रिंग प्रारूप में तारीख है, और <format> इन नियमों का पालन करने की तारीख प्रारूप है।

Syntax - दिनांक (<दिनांक-जैसा-स्ट्रिंग> [<प्रारूप>] [, <timezone>])

2

sysdate():

वर्तमान दिनांक और समय लौटाता है।

Syntax - sysdate ([<प्रारूप>] [, <timezone>])

3

format():

String.format () सम्मेलनों का उपयोग करते हुए एक प्रारूप बनाता है।

Syntax - प्रारूप (<प्रारूप> [, <arg1>] (, <arg-n>] *। Md)

4

distance():

हैवेरिन एल्गोरिथ्म का उपयोग करके ग्लोब में दो बिंदुओं के बीच की दूरी लौटाता है। निर्देशांक की डिग्री होनी चाहिए।

Syntax - दूरी (<x-field>, <y-field>, <x-value>, <y-value>)

5

ifnull():

पारित फ़ील्ड / मान लौटाता है (या वैकल्पिक पैरामीटर return_value_if_not_null)। यदि फ़ील्ड / मान शून्य नहीं है, तो यह return_value_if_null देता है।

Syntax - ifnull (<फ़ील्ड | मान>>, <return_value_if_null> [, <return_value_if_not_null>] (,, <फ़ील्ड & .md # 124; मूल्य>] *)

6

coalesce():

पहला क्षेत्र लौटाता है / मान शून्य पैरामीटर नहीं है। यदि कोई फ़ील्ड / मान शून्य नहीं है, तो शून्य देता है।

Syntax - समतल (<क्षेत्र | मान>> [, <क्षेत्र-एन | मान-एन>] *)

7

uuid():

लीच-सैलज़ वेरिएंट का उपयोग करके एक यूयूआईडी को 128-बिट मूल्य के रूप में उत्पन्न करता है।

Syntax - uuid ()

8

if():

एक शर्त (पहले पैरामीटर) का मूल्यांकन करता है और दूसरा पैरामीटर लौटाता है यदि स्थिति सही है, तो तीसरा अन्यथा।

Syntax - अगर (<अभिव्यक्ति>, <परिणाम-अगर-सच>, <परिणाम-अगर-गलत>)

निम्नलिखित प्रश्नों का उपयोग करके कुछ Misc फ़ंक्शन आज़माएं।

अभिव्यक्ति के निष्पादन के तरीके के बारे में जानने के लिए निम्नलिखित प्रश्न को निष्पादित करें।

orientdb {db = demo}> SELECT if(eval("name = 'satish'"), "My name is satish", 
"My name is not satish") FROM Employee

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

----+--------+----------------------- 
#   |@CLASS  | IF 
----+--------+----------------------- 
0   |null    |My name is satish  
1   |null    |My name is not satish 
2   |null    |My name is not satish  
3   |null    |My name is not satish  
4   |null    |My name is not satish  
----+--------+------------------------

सिस्टम दिनांक प्राप्त करने के लिए निम्न क्वेरी निष्पादित करें।

orientdb {db = demo}> SELECT SYSDATE() FROM Employee

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

----+--------+----------------------- 
#   |@CLASS  | SYSDATE 
----+--------+----------------------- 
0   |null    |2016-02-10 12:05:06 
1   |null    |2016-02-10 12:05:06 
2   |null    |2016-02-10 12:05:06 
3   |null    |2016-02-10 12:05:06 
4   |null    |2016-02-10 12:05:06 
----+--------+------------------------

इस फ़ंक्शन का अच्छी तरह से उपयोग करके आप आसानी से ओरिएंटबीडी डेटा में हेरफेर कर सकते हैं।

Sequencesऑटो इन्क्रीमेंट मैकेनिज्म में उपयोग की जाने वाली एक अवधारणा है और इसे ओरिएंटबीडी v2.2 में पेश किया गया है। डेटाबेस शब्दावली में, अनुक्रम एक संरचना है जो काउंटर फ़ील्ड का प्रबंधन करता है। सीधे शब्दों में कहा जाता है कि सीक्वेंस का इस्तेमाल ज्यादातर तब किया जाता है जब आपको ऐसे नंबर की जरूरत होती है जो हमेशा बढ़े। यह दो प्रकार का समर्थन करता है

ORDERED - हर बार पॉइंटर .next मेथड को कॉल करता है जो एक नया मान देता है।

CACHED- प्रत्येक नोड पर अनुक्रम 'एन' आइटम को कैश करेगा। प्रत्येक आइटम का उपयोग करने के लिए जिसे हम उपयोग करते हैं.next(), जो तब पसंद किया जाता है जब कैश में एक से अधिक आइटम होते हैं।

अनुक्रम बनाएँ

अनुक्रम का उपयोग आमतौर पर किसी व्यक्ति के आईडी मूल्य को बढ़ाने के लिए किया जाता है। ओरिएंटडीबी की अन्य एसक्यूएल अवधारणाओं की तरह यह भी आरडीबीएमएस में सीक्वेंस के समान संचालन को बेहतर बनाता है।

अनुक्रम बनाने के लिए निम्नलिखित कथन मूल वाक्यविन्यास है।

CREATE SEQUENCE <sequence> TYPE <CACHED|ORDERED> [START <start>]  
[INCREMENT <increment>] [CACHE <cache>]

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

<Sequence> - अनुक्रम के लिए स्थानीय नाम।

TYPE - ORDERED या CACHED अनुक्रम प्रकार को परिभाषित करता है।

START - प्रारंभिक मूल्य को परिभाषित करता है।

INCREMENT - प्रत्येक .next विधि कॉल के लिए वेतन वृद्धि को परिभाषित करता है।

CACHE - पूर्व-कैश के मूल्य की संख्या को परिभाषित करता है, उस स्थिति में जिसे आपने अनुक्रम प्रकार को कैश करने के लिए उपयोग किया था।

आइए हम 'seqid' नाम से एक अनुक्रम बनाते हैं जो 1201 नंबर से शुरू होता है। इस उदाहरण को अनुक्रम से लागू करने के लिए निम्नलिखित प्रश्नों को आज़माएं।

CREATE SEQUENCE seqid START 1201

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

Sequence created successfully

खाता तालिका का आईडी मान सम्मिलित करने के लिए अनुक्रम 'seqid' का उपयोग करने के लिए निम्नलिखित क्वेरी का प्रयास करें।

INSERT INTO Account SET id = sequence('seqid').next()

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

Insert 1 record(s) in 0.001000 sec(s)

ऑल्टर सीक्वेंस

ऑल्टर सीक्वेंस एक कमांड है जिसका इस्तेमाल सीक्वेंस के गुणों को बदलने के लिए किया जाता है। यह अनुक्रम प्रकार को छोड़कर सभी अनुक्रम विकल्पों को संशोधित करेगा।

निम्नलिखित कथन अनुक्रम को बदलने के लिए मूल वाक्यविन्यास है।

ALTER SEQUENCE <sequence> [START <start-point>] 
[INCREMENT <increment>] [CACHE <cache>]

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

<Sequence> - उस क्रम को परिभाषित करता है जिसे आप बदलना चाहते हैं।

START - प्रारंभिक मूल्य को परिभाषित करता है।

INCREMENT - प्रत्येक .next विधि कॉल के लिए वेतन वृद्धि को परिभाषित करता है।

CACHE - उस घटना में पूर्व-कैश के मूल्य की संख्या को परिभाषित करता है जो आपने अनुक्रम प्रकार को कैश करने के लिए उपयोग किया था।

Seqid नामक अनुक्रम के '1201 से 1000' के प्रारंभ मूल्य को बदलने के लिए निम्नलिखित क्वेरी का प्रयास करें।

ALTER SEQUENCE seqid START 1000

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

Altered sequence successfully

ड्रॉप सीक्वेंस

ड्रॉप सीक्वेंस एक कमांड है जिसका इस्तेमाल सीक्वेंस को ड्रॉप करने के लिए किया जाता है।

अनुक्रम को छोड़ने के लिए निम्नलिखित कथन मूल वाक्यविन्यास है।

DROP SEQUENCE <sequence>

कहाँ पे <Sequence> उस क्रम को परिभाषित करता है जिसे आप छोड़ना चाहते हैं।

'Seqid' नाम के अनुक्रम को छोड़ने के लिए निम्नलिखित क्वेरी का प्रयास करें।

DROP SEQUENCE seqid

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

Sequence dropped successfully

Index एक सूचक है जो डेटाबेस में डेटा के एक स्थान को इंगित करता है। Indexingएक अवधारणा है जिसका उपयोग डेटाबेस में हर रिकॉर्ड को खोजने के लिए डेटा को जल्दी से खोजने के लिए किया जाता है। OrientDB चार सूचकांक एल्गोरिदम और प्रत्येक के भीतर कई प्रकार का समर्थन करता है।

सूचकांक के चार प्रकार हैं -

एसबी-ट्री इंडेक्स

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

  • UNIQUE- ये इंडेक्स डुप्लिकेट कुंजियों की अनुमति नहीं देते हैं। कम्पोज़िट इंडेक्स के लिए, यह कम्पोज़िट कीज़ की विशिष्टता को संदर्भित करता है।

  • NOTUNIQUE - ये इंडेक्स डुप्लिकेट कुंजियों की अनुमति देते हैं।

  • FULLTEXT- ये इंडेक्स टेक्स्ट के किसी एक शब्द पर आधारित होते हैं। आप इनका उपयोग प्रश्नों के माध्यम से कर सकते हैंCONTAINSTEXT ऑपरेटर।

  • DICTIONARY - ये इंडेक्स यूनीक के समान होते हैं, लेकिन डुप्लिकेट चाबियों के मामले में, वे मौजूदा रिकॉर्ड को नए रिकॉर्ड से बदल देते हैं।

हैश इंडेक्स

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

  • UNIQUE_HASH_INDEX- ये इंडेक्स डुप्लिकेट कुंजियों की अनुमति नहीं देते हैं। कम्पोज़िट इंडेक्स के लिए, यह कम्पोज़िट कीज़ की विशिष्टता को संदर्भित करता है।

  • NOTUNIQUE_HASH_INDEX - ये इंडेक्स डुप्लिकेट कुंजियों की अनुमति देते हैं।

  • FULLTEXT_HASH_INDEX- ये इंडेक्स टेक्स्ट के किसी एक शब्द पर आधारित होते हैं। आप उन्हें CONTAINSTEXT ऑपरेटर के माध्यम से प्रश्नों में उपयोग कर सकते हैं।

  • DICTIONARY_HASH_INDEX - ये इंडेक्स उपयोग करने वालों के समान हैं UNIQUE_HASH_INDEX, लेकिन डुप्लिकेट कुंजियों के मामलों में, वे मौजूदा रिकॉर्ड को नए रिकॉर्ड के साथ बदल देते हैं।

ल्यूसिने फुल टेक्स्ट इंडेक्स

यह पूर्ण-पाठ अनुक्रमणिका प्रदान करता है, लेकिन इसका उपयोग अन्य प्रकारों को अनुक्रमित करने के लिए नहीं किया जा सकता है। यह टिकाऊ, लेन-देन योग्य है, और श्रेणी प्रश्नों का समर्थन करता है।

ल्यूसीन स्थानिक सूचकांक

यह अच्छा स्थानिक सूचकांक प्रदान करता है, लेकिन इसका उपयोग अन्य प्रकारों को अनुक्रमित करने के लिए नहीं किया जा सकता है। यह टिकाऊ, लेन-देन योग्य है, और श्रेणी प्रश्नों का समर्थन करता है।

अनुक्रमणिका बनाना

इंडेक्स बनाएँ एक कमांड एक विशेष स्कीमा पर एक इंडेक्स बनाने के लिए है।

अनुक्रमणिका बनाने के लिए निम्नलिखित कथन मूल वाक्यविन्यास है।

CREATE INDEX <name> [ON <class-name> (prop-names)] <type> [<key-type>] 
[METADATA {<metadata>}]

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

<name>- सूचकांक के लिए तार्किक नाम को परिभाषित करता है। स्कीमा प्रॉपर्टी से जुड़े ऑटोमैटिक इंडेक्स बनाने के लिए आप <class.property> नोटेशन का भी इस्तेमाल कर सकते हैं। <वर्ग> स्कीमा के वर्ग का उपयोग करता है और <संपत्ति> वर्ग में निर्मित संपत्ति का उपयोग करता है।

<class-name>- उस वर्ग का नाम प्रदान करता है जिसे आप अनुक्रमणिका के लिए स्वचालित अनुक्रमणिका बना रहे हैं। यह वर्ग डेटाबेस में मौजूद होना चाहिए।

<prop-names>- उन संपत्तियों की सूची प्रदान करता है, जिन्हें आप इंडेक्स के लिए ऑटोमैटिक इंडेक्स चाहते हैं। स्कीमा में ये गुण पहले से मौजूद होने चाहिए।

<type> - एल्गोरिथ्म और प्रकार के सूचकांक प्रदान करता है जिसे आप बनाना चाहते हैं।

<key-type> - स्वचालित इंडेक्स के साथ वैकल्पिक कुंजी प्रकार प्रदान करता है।

<metadata> - JSON प्रतिनिधित्व प्रदान करता है।

उदाहरण

उपयोगकर्ता sales_user की संपत्ति 'ID' के लिए स्वचालित सूचकांक बनाने के लिए निम्नलिखित क्वेरी का प्रयास करें।

orientdb> CREATE INDEX indexforID ON sales_user (id) UNIQUE

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

Creating index... 
Index created successfully with 4 entries in 0.021000 sec(s)

अनुक्रमित अनुक्रमित करना

आप इंडेक्स में रिकॉर्ड प्राप्त करने के लिए चुनिंदा क्वेरी का उपयोग कर सकते हैं।

अनुक्रमणिका की कुंजियों को 'indexforId' नाम से प्राप्त करने के लिए निम्नलिखित क्वेरी का प्रयास करें।

SELECT FROM INDEX:indexforId

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

----+------+----+----- 
#   |@CLASS|key |rid   
----+------+----+----- 
0   |null  |1   |#11:7 
1   |null  |2   |#11:6 
2   |null  |3   |#11:5 
3   |null  |4   |#11:8 
----+------+----+-----

ड्रॉप इंडेक्स

यदि आप किसी विशेष इंडेक्स को छोड़ना चाहते हैं, तो आप इस कमांड का उपयोग कर सकते हैं। यह ऑपरेशन लिंक किए गए रिकॉर्ड को नहीं हटाता है।

अनुक्रमणिका को छोड़ने के लिए निम्न कथन मूल वाक्यविन्यास है।

DROP INDEX <name>

कहाँ पे <name> उस इंडेक्स का नाम प्रदान करता है जिसे आप ड्रॉप करना चाहते हैं।

उपयोगकर्ता sales_user के 'ID' नाम के एक इंडेक्स को छोड़ने के लिए निम्नलिखित क्वेरी का प्रयास करें।

DROP INDEX sales_users.Id

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

Index dropped successfully

RDBMS की तरह, OrientDB लेनदेन ACID संपत्तियों का समर्थन करता है। एtransactionएक डेटाबेस प्रबंधन प्रणाली के भीतर किए गए कार्य की एक इकाई शामिल है। डेटाबेस वातावरण में लेनदेन बनाए रखने के दो मुख्य कारण हैं।

  • विफलताओं से समवर्ती वसूली की अनुमति देना और सिस्टम विफल होने की स्थिति में भी डेटाबेस को सुसंगत रखना।

  • एक डेटाबेस तक पहुँचने वाले कार्यक्रमों के बीच अलगाव प्रदान करने के लिए।

डिफ़ॉल्ट रूप से, डेटाबेस लेनदेन को ACID गुणों जैसे कि Atomic, Consistent, Isolated, और टिकाऊ गुणों का पालन करना चाहिए। लेकिन ओरिएंटबीडी एक एसीआईडी ​​कंप्लेंट डेटाबेस है, जिसका अर्थ है कि यह कॉन्सेप्ट ACID का खंडन या नकारात्मक नहीं करता है, लेकिन यह NoSQL डेटाबेस को संभालते हुए अपनी धारणा को बदल देता है। एक नजर डालिए कि ACID प्रॉपर्टीज NoSQL डेटाबेस के साथ कैसे काम करती है।

Atomic - जब आप डेटाबेस को बदलने के लिए कुछ करते हैं तो परिवर्तन को काम करना चाहिए या एक पूरे के रूप में विफल होना चाहिए।

Consistent - डेटाबेस सुसंगत रहना चाहिए।

Isolated - यदि एक ही समय में अन्य लेनदेन निष्पादित हो रहे हैं, तो उपयोगकर्ता रिकॉर्ड को समवर्ती निष्पादन में नहीं देख पाएगा।

Durable - अगर सिस्टम क्रैश (हार्डवेयर या सॉफ्टवेयर) होता है, तो डेटाबेस को बैकअप लेने में सक्षम होना चाहिए।

डेटाबेस ट्रांजैक्शन कमिट और रोलबैक कमांड्स का उपयोग करके प्राप्त किया जा सकता है।

कमिट

कमिट का अर्थ है, डेटाबेस के सभी परिवर्तनों को सहेजकर लेनदेन को बंद करना। रोलबैक का अर्थ उस डेटाबेस स्थिति को पुनर्प्राप्त करना है जहां आपने लेन-देन खोला है।

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

COMMIT

Note - आप इस कमांड का उपयोग किसी विशेष डेटाबेस से कनेक्ट करने और लेनदेन शुरू करने के बाद ही कर सकते हैं।

उदाहरण

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

आपको पहले निम्नलिखित BEGIN कमांड का उपयोग करके लेनदेन शुरू करना होगा।

orientdb {db = demo}> BEGIN

निम्नलिखित आदेश का उपयोग करके आईडी = 12 और नाम = satish.P के साथ एक कर्मचारी तालिका में एक रिकॉर्ड डालें।

orientdb> INSERT INTO employee (id, name) VALUES (12, 'satish.P')

लेन-देन करने के लिए आप निम्न आदेश का उपयोग कर सकते हैं।

orientdb> commit

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

Transaction 2 has been committed in 4ms

रोलबैक

रोलबैक का मतलब उस स्थिति में डेटाबेस स्थिति को पुनर्प्राप्त करना है जहां आपने लेनदेन खोला था।

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

ROLLBACK

Note - आप इस कमांड का उपयोग किसी विशेष डेटाबेस से कनेक्ट करने और लेनदेन शुरू करने के बाद ही कर सकते हैं।

उदाहरण

इस उदाहरण में, हम 'डेमो' नाम के उसी डेटाबेस का उपयोग करेंगे जो हमने ट्यूटोरियल के पहले अध्याय में बनाया था। हम रोलबैक लेन-देन के संचालन को देखेंगे और लेनदेन का उपयोग करके एक रिकॉर्ड स्टोर करेंगे।

आपको पहले निम्नलिखित BEGIN कमांड का उपयोग करके लेनदेन शुरू करना होगा।

orientdb {db = demo}> BEGIN

निम्नलिखित आदेश का उपयोग करके आईडी = 12 और नाम = satish.P के साथ एक कर्मचारी तालिका में एक रिकॉर्ड डालें।

orientdb> INSERT INTO employee (id, name) VALUES (12, 'satish.P')

टेबल कर्मचारी के रिकॉर्ड को पुनः प्राप्त करने के लिए आप निम्न कमांड का उपयोग कर सकते हैं।

orientdb> SELECT FROM employee WHERE name LIKE '%.P'

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

---+-------+-------------------- 
 # | ID   | name 
---+-------+-------------------- 
 0 | 12   | satish.P 
---+-------+-------------------- 
1 item(s) found. Query executed in 0.076 sec(s).

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

orientdb> ROLLBACK

कर्मचारी तालिका से उसी रिकॉर्ड को पुनः प्राप्त करने के लिए फिर से चयन करें क्वेरी की जाँच करें।

orientdb> SELECT FROM employee WHERE name LIKE '%.P'

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

0 item(s) found. Query executed in 0.037 sec(s).

OrientDB Hooksडेटाबेस शब्दावली में ट्रिगर के अलावा कुछ भी नहीं है जो उपयोगकर्ता अनुप्रयोगों में प्रत्येक सीआरयूडी संचालन से पहले और बाद में आंतरिक घटनाओं को सक्षम करता है। आप कस्टम सत्यापन नियमों को लिखने के लिए, सुरक्षा को लागू करने के लिए या एक रिलेशनल DBMS के खिलाफ प्रतिकृति जैसी बाहरी घटनाओं की व्यवस्था करने के लिए हुक का उपयोग कर सकते हैं।

ओरिएंटबीडी हुक के दो प्रकारों का समर्थन करता है -

Dynamic Hook - ट्रिगर, जिसे क्लास लेवल और / या डॉक्यूमेंट लेवल पर बनाया जा सकता है।

Java (Native) Hook - ट्रिगर, जो जावा कक्षाओं का उपयोग करके बनाया जा सकता है।

गतिशील हुक

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

अपने दस्तावेजों के खिलाफ हुक निष्पादित करने के लिए, पहले अपनी कक्षाओं का विस्तार करने की अनुमति दें OTriggeredआधार वर्ग। बाद में, इच्छुक घटना के लिए एक कस्टम संपत्ति को परिभाषित करें। उपलब्ध घटनाओं का अनुसरण कर रहे हैं।

  • onBeforeCreate - फोन किया before एक नया दस्तावेज़ बनाना।

  • onAfterCreate - फोन किया after एक नया दस्तावेज़ बनाना।

  • onBeforeRead - फोन किया before एक दस्तावेज़ पढ़ना।

  • onAfterRead - फोन किया after एक दस्तावेज़ पढ़ना।

  • onBeforeUpdate - फोन किया before एक दस्तावेज़ को अद्यतन करना।

  • onAfterUpdate - फोन किया after एक दस्तावेज़ को अद्यतन करना।

  • onBeforeDelete - फोन किया before दस्तावेज़ हटाना।

  • onAfterDelete - फोन किया after दस्तावेज़ हटाना।

डायनेमिक हुक कह सकते हैं -

  • कार्य, SQL, जावास्क्रिप्ट या ओरिएंटबीडी और JVM द्वारा समर्थित किसी भी भाषा में लिखा गया है।

  • जावा स्थिर विधियाँ।

कक्षा स्तर के हुक

क्लास लेवल हुक को उन सभी दस्तावेजों के लिए परिभाषित किया जाता है जो एक क्लास से संबंधित हैं। निम्नलिखित एक हुक स्थापित करने के लिए एक उदाहरण है जो इनवॉइस दस्तावेजों के खिलाफ वर्ग स्तर पर कार्य करता है।

CREATE CLASS Invoice EXTENDS OTriggered 
ALTER CLASS Invoice CUSTOM onAfterCreate = invoiceCreated

चलिए फंक्शन बनाते हैं invoiceCreated जावास्क्रिप्ट में जो सर्वर में प्रिंट करता है वह बनाए गए इनवॉइस नंबर को कंसोल करता है।

CREATE FUNCTION invoiceCreated "print('\\nInvoice created: ' + doc.field ('number'));"
LANGUAGE Javascript

अब एक नया बनाकर हुक का प्रयास करें Invoice दस्तावेज़।

INSERT INTO Invoice CONTENT {number: 100, notes: 'This is a test}

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

Invoice created: 100

दस्तावेज़ स्तर हुक

आप केवल एक या अधिक दस्तावेजों के खिलाफ एक विशेष कार्रवाई को परिभाषित कर सकते हैं। ऐसा करने के लिए, अपनी कक्षा को विस्तारित करने की अनुमति देंOTriggered कक्षा।

उदाहरण के लिए, हमें एक ट्रिगर निष्पादित करें, जावास्क्रिप्ट फ़ंक्शन के रूप में, एक मौजूद प्रोफाइल वर्ग के खिलाफ, संपत्ति खाते के साथ सभी दस्तावेजों के लिए = 'प्रीमियम'। दस्तावेजों को हटाने से रोकने के लिए ट्रिगर को बुलाया जाएगा।

ALTER CLASS Profile SUPERCLASS OTriggered UPDATE Profile 
SET onBeforeDelete = 'preventDeletion' WHERE account = 'Premium'

आइए बनाते हैं preventDeletion() जावास्क्रिप्ट समारोह।

CREATE FUNCTION preventDeletion "throw new java.lang.RuntimeException('Cannot 
delete Premium profile ' + doc)" LANGUAGE Javascript

और फिर 'प्रीमियम' खाते को हटाने की कोशिश करके हुक का परीक्षण करें।

DELETE FROM #12:1 
java.lang.RuntimeException: Cannot delete Premium profile
profile#12:1{onBeforeDelete:preventDeletion,account:Premium,name:Jill} v-1 
(<Unknown source>#2) in <Unknown source> at line number 2

जावा हुक

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

बनाने से पहले, आपको डाउनलोड करना होगा orientdb-core.jarनिम्नलिखित लिंक पर जाकर फाइल को डाउनलोड करें ओरिएंटबीडी कोर । और बाद में उस जार फ़ाइल को उस फ़ोल्डर में कॉपी करें जहाँ आप जावा सोर्स फाइल को स्टोर करना चाहते हैं।

हुक फ़ाइल बनाएँ

नाम से एक जावा फ़ाइल बनाएँ HookTest.java, जो जावा भाषा का उपयोग करके हुक तंत्र का परीक्षण करेगा।

import java.io.BufferedReader; 
import java.io.FileNotFoundException; 
import java.io.InputStream; 
import java.io.InputStreamReader; 
import java.io.StringReader; 
import java.util.ArrayList; 
import java.util.List; 
import java.util.concurrent.locks.ReentrantLock; 
import com.orientechnologies.orient.core.hook.ODocumentHookAbstract; 
import com.orientechnologies.orient.core.hook.ORecordHook; 
import com.orientechnologies.orient.core.hook.ORecordHookAbstract; 
import com.orientechnologies.orient.core.db.ODatabaseLifecycleListener; 
import com.orientechnologies.orient.core.db.ODatabase; 
import com.orientechnologies.orient.core.record.ORecord; 
import com.orientechnologies.orient.core.record.impl.ODocument;
  
public class HookTest extends ODocumentHookAbstract implements ORecordHook { 
   public HookTest() {
  
   }
  
   @Override 
   public DISTRIBUTED_EXECUTION_MODE getDistributedExecutionMode() { 
      return DISTRIBUTED_EXECUTION_MODE.BOTH; 
   } 
   public RESULT onRecordBeforeCreate( ODocument iDocument ) { 
      System.out.println("Ran create hook"); 
      return ORecordHook.RESULT.RECORD_NOT_CHANGED; 
   } 
   public RESULT onRecordBeforeUpdate( ODocument iDocument ) { 
      System.out.println("Ran update hook"); 
      return ORecordHook.RESULT.RECORD_NOT_CHANGED;  
   }  
}

उपरोक्त नमूना कोड आपके द्वारा उस कक्षा के रिकॉर्ड को बनाते या अद्यतन करने पर हर बार उपयुक्त टिप्पणी छापता है।

आइए एक और हुक फ़ाइल जोड़ें setCreatedUpdatedDates.java निम्नानुसार है -

import java.io.BufferedReader; 
import java.io.FileNotFoundException; 
import java.io.InputStream; 
import java.io.InputStreamReader; 
import java.io.StringReader; 
import java.util.ArrayList; 
import java.util.List; 
import java.util.concurrent.locks.ReentrantLock; 
import com.orientechnologies.orient.core.hook.ODocumentHookAbstract; 
import com.orientechnologies.orient.core.hook.ORecordHook; 
import com.orientechnologies.orient.core.hook.ORecordHookAbstract; 
import com.orientechnologies.orient.core.db.ODatabaseLifecycleListener; 
import com.orientechnologies.orient.core.db.ODatabase; 
import com.orientechnologies.orient.core.record.ORecord; 
import com.orientechnologies.orient.core.record.impl.ODocument; 
 
public class setCreatedUpdatedDates extends ODocumentHookAbstract implements ORecordHook { 
   public setCreatedUpdatedDates() { 
   
   }
   
   @Override 
   public DISTRIBUTED_EXECUTION_MODE getDistributedExecutionMode() { 
      return DISTRIBUTED_EXECUTION_MODE.BOTH; 
   } 
   public RESULT onRecordBeforeCreate( ODocument iDocument ) { 
      if ((iDocument.getClassName().charAt(0) == 't') || (iDocument.getClassName().charAt(0)=='r')) { 
         iDocument.field("CreatedDate", System.currentTimeMillis() / 1000l); 
         iDocument.field("UpdatedDate", System.currentTimeMillis() / 1000l); 
         return ORecordHook.RESULT.RECORD_CHANGED; 
      } else { 
         return ORecordHook.RESULT.RECORD_NOT_CHANGED; 
      } 
   } 
   
   public RESULT onRecordBeforeUpdate( ODocument iDocument ) { 
      if ((iDocument.getClassName().charAt(0) == 't') || (iDocument.getClassName().charAt(0)=='r')) { 
         iDocument.field("UpdatedDate", System.currentTimeMillis() / 1000l); 
         return ORecordHook.RESULT.RECORD_CHANGED; 
      } else { 
         return ORecordHook.RESULT.RECORD_NOT_CHANGED; 
      } 
   }  
}

उपरोक्त कोड किसी भी वर्ग के लिए क्या है जो अक्षरों से शुरू होता है 'r''t'और रिकॉर्ड बनाया और सेट हो जाता है और अद्यतन अद्यतन हो जाता है, तो हर बार अद्यतन किया जाता है बस सेट करता है।

संकलित जावा हुक

निम्न आदेश का उपयोग करके जावा कोड संकलित करें। Note: डाउनलोड की गई जार फाइल और इन जावा फाइलों को एक ही फोल्डर में रखें।

$ jar cf hooks-1.0-SNAPSHOT.jar *.java

संकलित कोड को जहां ओरिएंटबीडी सर्वर ले जा सकते हैं, वहां ले जाएं

आपको तैयार .jar फ़ाइल को उस निर्देशिका में कॉपी करना होगा जहां आपका ओरिएंटबीडी सर्वर उनके लिए दिखेगा। इसका मतलब है './lib'ओरिएंटबीडी सर्वर रूट डायरेक्टरी के तहत फ़ोल्डर इस तरह दिखेगा -

$ cp hooks-1.0-SNAPSHOT.jar "$ORIENTDB_HOME/lib"

OrientDB सर्वर कॉन्फ़िगरेशन फ़ाइल में टेस्ट हुक को सक्षम करें

संपादित करें $ORIENTDB_HOME/config/orientdb-server-config.xml और फ़ाइल के अंत के पास निम्न अनुभाग जोड़ें।

<hooks> 
      <hook class = "HookTest" position = "REGULAR"/> 
   </hooks> 
   ... 
</orient-server>

ओरिएंटबीडी सर्वर को पुनरारंभ करें

एक बार जब आप ओरिएंटबीडी सर्वर को पुनरारंभ करते हैं, तो आपके द्वारा परिभाषित हुक orientdb-server-config.xmlअब सक्रिय है। एक OrientDB कंसोल लॉन्च करें, इसे अपने डेटाबेस से कनेक्ट करें, और निम्न कमांड चलाएं -

INSERT INTO V SET ID = 1;

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

Ran create hook

अब निम्नलिखित कमांड चलाएँ -

UPDATE V SET ID = 2 WHERE ID = 1;

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

Ran update hook

OrientDB सर्वर कॉन्फ़िगरेशन फ़ाइल में रियल हुक को सक्षम करें

संपादित करें $ORIENTDB_HOME/config/orientdb-server-config.xml और हुक सेक्शन को इस प्रकार बदलें -

<hooks> 
      <hook class="setCreatedUpdatedDates" position="REGULAR"/> 
   </hooks> 
   ... 
</orient-server>

ओरिएंटबीडी सर्वर को पुनरारंभ करें

एक नया वर्ग बनाएं जो अक्षर से शुरू होता है 'r''t'-

CREATE CLASS tTest EXTENDS V;

अब एक रिकॉर्ड डालें -

INSERT INTO tTest SET ID = 1 
SELECT FROM tTest

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

----+-----+------+----+-----------+----------- 
#   |@RID |@CLASS|ID  |CreatedDate|UpdatedDate 
----+-----+------+----+-----------+----------- 
0   |#19:0|tTest |1   |1427597275 |1427597275 
----+-----+------+----+-----------+-----------

भले ही आपने मानों को निर्धारित करने के लिए निर्दिष्ट नहीं किया है CreatedDate तथा UpdatedDate, OrientDB ने आपके लिए इन फ़ील्ड्स को स्वचालित रूप से सेट किया है।

अगला आपको निम्नलिखित कमांड का उपयोग करके रिकॉर्ड को अपडेट करने की आवश्यकता है -

UPDATE tTest SET ID = 2 WHERE ID = 1; 
SELECT FROM tTest;

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

----+-----+------+----+-----------+----------- 
#   |@RID |@CLASS|ID  |CreatedDate|UpdatedDate 
----+-----+------+----+-----------+----------- 
0   |#19:0|tTest |2   |1427597275 |1427597306 
----+-----+------+----+-----------+-----------

आप देख सकते हैं कि ओरिएंटबीडी ने बदल दिया है UpdatedDate लेकिन चलो CreatedDate कोई बदलाव नहीं।

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

Cachingएक अवधारणा है जो उपयोगकर्ता अनुप्रयोगों के लिए आरामदायक वातावरण प्रदान करने वाली डेटाबेस तालिका संरचना की एक प्रति बनाएगी। ओरिएंटबीडी में विभिन्न स्तरों पर कई कैशिंग तंत्र हैं।

निम्नलिखित उदाहरण कैशिंग क्या है के बारे में एक विचार देता है।

उपरोक्त दृष्टांत में DB1, DB2, DB3 एक अनुप्रयोग में उपयोग किए जाने वाले तीन अलग-अलग डेटाबेस उदाहरण हैं।

Level-1 कैश एक है Local cacheजो एक विशिष्ट सत्र द्वारा ज्ञात सभी संस्थाओं को संग्रहीत करता है। यदि आपके पास इस सत्र में तीन लेनदेन हैं, तो यह सभी तीन लेनदेन द्वारा उपयोग की जाने वाली सभी संस्थाओं को रखेगा। जब आप सत्र बंद करते हैं या जब आप "स्पष्ट" विधि करते हैं, तो यह कैश साफ़ हो जाता है। यह एप्लिकेशन और डेटाबेस के बीच I / O संचालन के बोझ को कम करता है और बदले में प्रदर्शन को बढ़ाता है।

Level-2 कैश एक है Real cacheवह तीसरे पक्ष के प्रदाता का उपयोग करके काम करता है। कैश की सामग्री पर आपका पूर्ण नियंत्रण हो सकता है, अर्थात आप यह निर्दिष्ट करने में सक्षम होंगे कि कौन सी प्रविष्टियाँ हटा दी जानी चाहिए, किन लोगों को लंबे समय तक संग्रहीत किया जाना चाहिए। यह कई थ्रेड्स के बीच पूर्ण साझा कैश है।

Storage model स्टोरेज डिवाइस के अलावा कुछ भी नहीं है जो डिस्क, मेमोरी या रिमोट सर्वर है।

ओरिएंटबीडी में कैश कैसे काम करता है?

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

स्थानीय मोड (एंबेडेड डाटाबेस)

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

जब क्लाइंट एप्लिकेशन निम्नलिखित के लिए एक रिकॉर्ड ओरिएंटबीडी चेक की मांग करता है -

  • यदि कोई लेन-देन शुरू हो गया है, तो यह बदले हुए रिकॉर्ड के लिए लेनदेन के अंदर खोज करता है और यदि मिला तो वापस कर देता है।

  • यदि स्थानीय कैश सक्षम है और इसमें अनुरोधित रिकॉर्ड है, तो उसे वापस लौटा दें।

  • यदि इस बिंदु पर रिकॉर्ड कैश में नहीं है, तो इसे स्टोरेज (डिस्क, मेमोरी) के लिए कहता है।

क्लाइंट सर्वर मोड (दूरस्थ डेटाबेस)

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

जब क्लाइंट एप्लिकेशन रिकॉर्ड मांगता है, तो ओरिएंटीडीबी निम्नलिखित के लिए जांच करता है -

  • यदि कोई लेन-देन शुरू हो गया है, तो यह बदले हुए रिकॉर्ड के लिए लेनदेन के अंदर खोज करता है और यदि मिला तो वापस कर देता है।

  • यदि स्थानीय कैश सक्षम है और इसमें अनुरोधित रिकॉर्ड है, तो उसे वापस लौटा दें।

  • इस बिंदु पर, यदि रिकॉर्ड कैश में नहीं है, तो इसे टीसीपी / आईपी कॉल के माध्यम से सर्वर से मांगें।

  • सर्वर में, यदि स्थानीय कैश सक्षम है और इसमें अनुरोधित रिकॉर्ड है, तो उसे वापस लौटा दें।

  • इस बिंदु पर, अभी भी रिकॉर्ड सर्वर में कैश्ड नहीं है, फिर इसे स्टोरेज (डिस्क, मेमोरी) के लिए कहता है।

ओरिएंटबैंक जावा वर्चुअल मशीन के साथ बंडल किए गए जावा लॉगिंग ढांचे का उपयोग करता है। OrientDB के डिफ़ॉल्ट लॉग प्रारूप द्वारा प्रबंधित किया जाता हैOLogFormatter कक्षा।

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

<date> <level> <message> [<requester>]

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

<date> - यह निम्नलिखित प्रारूप में लॉग की तारीख है: yyyy-MM-dd HH: mm: ss: SSS।

<level> - यह 5 चार्ट आउटपुट के रूप में लॉगिंग स्तर है।

<message> - यह लॉग का पाठ है, यह किसी भी आकार का हो सकता है।

[<class>] - यह जावा वर्ग है जो लॉग (वैकल्पिक) है।

समर्थित स्तर वे हैं जो जेआरई वर्ग java.util.log.Level में निहित हैं। वे हैं -

  • कभी (उच्चतम मूल्य)
  • WARNING
  • INFO
  • CONFIG
  • FINE
  • FINER
  • सबसे कम (न्यूनतम मूल्य)

डिफ़ॉल्ट रूप से, दो लकड़हारे स्थापित होते हैं -

  • Console, शेल के आउटपुट के रूप में / कमांड प्रॉम्प्ट जो एप्लिकेशन / सर्वर को शुरू करता है। चर 'log.console.level' को सेट करके बदला जा सकता है।

  • File, लॉग फ़ाइलों के आउटपुट के रूप में। 'Log.file.level' सेट करके बदला जा सकता है।

लॉगिंग को कॉन्फ़िगर करें

लॉगिंग रणनीतियों और नीतियों को जावा के बाद एक फ़ाइल का उपयोग करके कॉन्फ़िगर किया जा सकता है।

syntax - जावा लॉगिंग कॉन्फ़िगरेशन।

उदाहरण

निम्न सामग्री से कॉपी करें orientdb-server-log.properties फ़ाइल और इसे में डाल दिया $ORIENTDB_HOME/config फ़ाइल।

# Specify the handlers to create in the root logger 
# (all loggers are children of the root logger) 
# The following creates two handlers 
handlers = java.util.logging.ConsoleHandler, java.util.logging.FileHandler 
# Set the default logging level for the root logger 
.level = ALL 
 
# Set the default logging level for new ConsoleHandler instances 
java.util.logging.ConsoleHandler.level = INFO 
# Set the default formatter for new ConsoleHandler instances 
java.util.logging.ConsoleHandler.formatter = 
   com.orientechnologies.common.log.OLogFormatter 
 
# Set the default logging level for new FileHandler instances 
java.util.logging.FileHandler.level = INFO 
# Naming style for the output file 
java.util.logging.FileHandler.pattern =../log/orient-server.log 
# Set the default formatter for new FileHandler instances 
java.util.logging.FileHandler.formatter = com.orientechnologies.common.log.OLogFormatter 
# Limiting size of output file in bytes: 
java.util.logging.FileHandler.limit = 10000000 
# Number of output files to cycle through, by appending an 
# integer to the base file name: 
java.util.logging.FileHandler.count = 10

JVM को यह बताने के लिए कि गुण फ़ाइल कहाँ रखी गई है, आपको "सेट करने की आवश्यकता है"java.util.logging.config.file"इसके लिए सिस्टम प्रॉपर्टी। उदाहरण के लिए, निम्न कमांड का उपयोग करें -

$ java -Djava.util.logging.config.file=mylog.properties ...

लॉगिंग स्तर सेट करें

लॉगिंग कॉन्फ़िगरेशन को संशोधित किए बिना लॉगिंग स्तर को बदलने के लिए, बस "सेट करें"log.console.level" तथा "log.file.level"सिस्टम अनुरोधित स्तरों पर चर करता है।

स्टार्टअप पर लॉग इन करना

निम्नलिखित विभिन्न स्तरों पर स्टार्टअप स्तर पर लॉगिंग सेट करने की प्रक्रियाएँ हैं।

सर्वर कॉन्फ़िगरेशन में

फ़ाइल खोलें orientdb-server-config.xml और <गुण> अनुभाग के अंदर फ़ाइल के अंत में इन पंक्तियों को जोड़ें या अपडेट करें -

<entry value = "fine" name = "log.console.level" /> 
<entry value = "fine" name = "log.file.level" />

Server.sh (या .bat) स्क्रिप्ट में

सिस्टम प्रॉपर्टी सेट करें "log.console.level" तथा "log.file.level"जावा के -D पैरामीटर का उपयोग करके आप जो स्तर चाहते हैं।

$ java -Dlog.console.level = FINE ...

रन-टाइम पर लॉग इन करना

निम्नलिखित विभिन्न स्तरों पर स्टार्टअप स्तर पर लॉगिंग सेट करने की प्रक्रियाएँ हैं।

जावा कोड का उपयोग करके

सिस्टम वेरिएबल को System.setProperty () API का उपयोग करके स्टार्टअप पर सेट किया जा सकता है। निम्न कोड स्निपेट जावा कोड का उपयोग करके लॉगिंग स्तर सेट करने के लिए सिंटैक्स है।

public void main(String[] args){ 
   System.setProperty("log.console.level", "FINE"); 
   ... 
}

रिमोट सर्वर पर

URL के विरुद्ध HTTP POST निष्पादित करें: /server/log.<type> / <level>, जहां -

  • <प्रकार> "कंसोल" या "फ़ाइल" हो सकता है
  • <स्तर> समर्थित स्तरों में से एक है

उदाहरण

निम्नलिखित उदाहरण का उपयोग करता है cURLOrientDB सर्वर के खिलाफ HTTP POST कमांड निष्पादित करने के लिए। सर्वर के "रूट" उपयोगकर्ता और पासवर्ड का उपयोग किया गया, अपने स्वयं के पासवर्ड के साथ बदलें।

कंसोल के लिए बेहतरीन अनुरेखण स्तर सक्षम करें -

curl -u root:root -X POST http://localhost:2480/server/log.console/FINEST

फ़ाइल के लिए सर्वोत्तम अनुरेखण स्तर सक्षम करें -

curl -u root:root -X POST http://localhost:2480/server/log.file/FINEST

इस अध्याय में, आप ओरिएंटबीडी का उपयोग करने वाले अपने एप्लिकेशन को अनुकूलित करने के तरीके के बारे में कुछ सामान्य सुझाव प्राप्त कर सकते हैं। विभिन्न प्रकार के डेटाबेस के लिए प्रदर्शन बढ़ाने के तीन तरीके हैं।

  • Document Database Performance Tuning - यह एक ऐसी तकनीक का उपयोग करता है जो हर नए दस्तावेज़ के लिए दस्तावेज़ निर्माण से बचने में मदद करता है।

  • Object Database Performance Tuning - यह प्रदर्शन को बेहतर बनाने के लिए जेनेरिक तकनीकों का उपयोग करता है।

  • Distributed Configuration Tuning - यह वितरित कॉन्फ़िगरेशन में प्रदर्शन को बेहतर बनाने के लिए विभिन्न तरीकों का उपयोग करता है।

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

मेमोरी सेटिंग्स

प्रदर्शन सुधारने के लिए मेमोरी सेटिंग में अलग-अलग रणनीतियाँ हैं।

सर्वर और एंबेडेड सेटिंग्स

ये सेटिंग्स सर्वर घटक और JVM दोनों के लिए मान्य हैं, जहाँ Java अनुप्रयोग OrientDB एंबेडेड मोड में सीधे प्रयोग करके चलाया जाता है plocal

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

उदाहरण के लिए, यदि आप Java प्रक्रिया में अधिकतम 8GB असाइन कर सकते हैं, तो आमतौर पर छोटे हीप और बड़े डिस्क कैश बफर (ऑफ-हीप मेमोरी) को असाइन करना बेहतर होता है।

हीप मेमोरी बढ़ाने के लिए निम्न कमांड का प्रयास करें।

java -Xmx800m -Dstorage.diskCache.bufferSize=7200 ...

storage.diskCache.bufferSize सेटिंग (पुराने "स्थानीय" भंडारण के साथ यह था file.mmap.maxMemory) एमबी में है और बताता है कि डिस्क कैश घटक के लिए कितनी मेमोरी का उपयोग करना है। डिफ़ॉल्ट रूप से यह 4GB है।

NOTE - यदि अधिकतम हीप और डिस्क कैश बफर का योग बहुत अधिक है, तो यह ओएस को बड़ी मंदी के साथ स्वैप करने का कारण बन सकता है।

जेवीएम सेटिंग्स

JVM सेटिंग्स को सर्वर.sh (और server.bat) बैच फ़ाइलों में एन्कोड किया गया है। आप अपने उपयोग और hw / sw सेटिंग्स के अनुसार जेवीएम को ट्यून करने के लिए उन्हें बदल सकते हैं। निम्न लाइन को server.bat फ़ाइल में जोड़ें।

-server -XX:+PerfDisableSharedMem

यह सेटिंग JVM के बारे में डिबग जानकारी लिखने को अक्षम कर देगी। यदि आपको जेवीएम को प्रोफाइल करने की आवश्यकता है, तो इस सेटिंग को हटा दें।

रिमोट कनेक्शन

दूरस्थ कनेक्शन का उपयोग करके डेटाबेस तक पहुँचने पर प्रदर्शन को बेहतर बनाने के कई तरीके हैं।

रणनीति लाना

जब आप एक दूरस्थ डेटाबेस के साथ काम करते हैं तो आपको इस्तेमाल की गई रणनीति पर ध्यान देना होगा। डिफ़ॉल्ट रूप से, ओरिएंटडीबी क्लाइंट केवल परिणाम में निहित रिकॉर्ड को लोड करता है। उदाहरण के लिए, यदि कोई क्वेरी 100 तत्वों को लौटाती है, लेकिन यदि आप क्लाइंट से इन तत्वों को पार करते हैं, तो ओरिएंटीडीबी क्लाइंट प्रत्येक मिस्ड रिकॉर्ड के लिए सर्वर पर एक और नेटवर्क कॉल के साथ तत्वों को लोड करता है।

नेटवर्क कनेक्शन पूल

प्रत्येक क्लाइंट, डिफ़ॉल्ट रूप से, सर्वर के साथ बात करने के लिए केवल एक नेटवर्क कनेक्शन का उपयोग करता है। एक ही क्लाइंट पर कई थ्रेड्स समान नेटवर्क कनेक्शन पूल साझा करते हैं।

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

विन्यास बहुत सरल है, सिर्फ 2 पैरामीटर -

  • minPool- यह कनेक्शन पूल का प्रारंभिक आकार है। डिफ़ॉल्ट मान को वैश्विक पैरामीटर "client.channel.minPool" के रूप में कॉन्फ़िगर किया गया है।

  • maxPool- यह अधिकतम आकार है जो कनेक्शन पूल तक पहुंच सकता है। डिफ़ॉल्ट मान को वैश्विक पैरामीटर "client.channel.maxPool" के रूप में कॉन्फ़िगर किया गया है।

यदि सभी पूल कनेक्शन व्यस्त हैं, तो क्लाइंट थ्रेड पहले मुफ्त कनेक्शन की प्रतीक्षा करेगा।

डेटाबेस गुणों का उपयोग करके कॉन्फ़िगरेशन का उदाहरण।

database = new ODatabaseDocumentTx("remote:localhost/demo"); 
database.setProperty("minPool", 2); 
database.setProperty("maxPool", 5);  

database.open("admin", "admin");

वितरित कॉन्फ़िगरेशन ट्यूनिंग

वितरित कॉन्फ़िगरेशन पर प्रदर्शन को बेहतर बनाने के कई तरीके हैं।

लेन-देन का उपयोग करें

यहां तक ​​कि जब आप ग्राफ़ अपडेट करते हैं, तो आपको हमेशा लेनदेन में काम करना चाहिए। OrientDB आपको उनके बाहर काम करने की अनुमति देता है। सामान्य मामले केवल पढ़ने के लिए प्रश्न हैं या विफलता के मामले में बड़े पैमाने पर और असंबद्ध संचालन बहाल किए जा सकते हैं। जब आप वितरित कॉन्फ़िगरेशन पर चलते हैं, तो लेन-देन का उपयोग विलंबता को कम करने में मदद करता है। ऐसा इसलिए है क्योंकि वितरित ऑपरेशन केवल प्रतिबद्ध समय पर होता है। विलंबता के कारण, एक से अधिक बड़े ऑपरेशनों को स्थानांतरित करने की तुलना में एक बड़े ऑपरेशन को वितरित करना बहुत अधिक कुशल है।

प्रतिकृति बनाम साझाकरण

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

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

राइट्स पर स्केल

यदि आपके पास एक धीमा नेटवर्क है और आपके पास एक सिंक्रोनस (डिफ़ॉल्ट) प्रतिकृति है, तो आप विलंबता की लागत का भुगतान कर सकते हैं। वास्तव में जब ओरिएंटडीबी सिंक्रोनाइज़ करता है, तो यह कम से कम इंतजार करता हैwriteQuorum। इसका मतलब यह है कि अगर राइटअकोरम 3 है, और आपके पास 5 नोड्स हैं, तो समन्वयक सर्वर नोड (जहां वितरित ऑपरेशन शुरू किया गया है) को क्लाइंट को जवाब देने के लिए कम से कम 3 नोड्स से उत्तर की प्रतीक्षा करनी होगी।

स्थिरता बनाए रखने के लिए, राइटअकोरम को बहुमत पर सेट किया जाना चाहिए। यदि आपके पास 5 नोड हैं, तो बहुमत 3 है। 4 नोड्स के साथ, यह अभी भी 3 है। 4 या 5 के बजाय 3 को राइटक्कोरम सेट करना विलंबता लागत को कम करने और अभी भी स्थिरता बनाए रखने की अनुमति देता है।

अतुल्यकालिक प्रतिकृति

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

रीड्स पर स्केल

यदि आप पहले से ही अधिकांश नोड्स के लिए राइटअकोरम सेट करते हैं, तो आप इसे छोड़ सकते हैं readQuorumसे 1 (डिफ़ॉल्ट)। यह सभी रीड्स को गति देता है।

उन्नयन करते समय, आपको संस्करण संख्या और प्रारूप पर विचार करना होगा। तीन प्रकार के प्रारूप हैं - MAJOR, MINOR, PATCH।

  • MAJOR संस्करण असंगत एपीआई परिवर्तनों की ओर इशारा करता है।

  • MINOR संस्करण पिछड़े-संगत तरीके से कार्यक्षमता को बढ़ाता है।

  • PTCH संस्करण पिछड़े-संगत बग को ठीक करता है।

छोटे और प्रमुख संस्करणों के बीच तालमेल करने के लिए, आपको डेटाबेस निर्यात और आयात करने की आवश्यकता हो सकती है। कभी-कभी आपको बहुत से डेटाबेस को LOCAL से PLOCAL में स्थानांतरित करने की आवश्यकता होती है और ग्राफ़ को RidBag पर स्थानांतरित करने की आवश्यकता होती है।

LOCAL संग्रहण इंजन से PLOCAL पर माइग्रेट करें

संस्करण 1.5.x से शुरू करके OrientDB एक नए स्टोरेज इंजन के साथ आता है: PLOCAL (Paginated LOCAL)। यह LOCAL की तरह लगातार है, लेकिन एक अलग तरीके से जानकारी संग्रहीत करता है। निम्नलिखित बिंदु PLOCAL और LOCAL के बीच तुलना दर्शाते हैं -

  • PLOCAL रिकॉर्ड्स को क्लस्टर फ़ाइलों में संग्रहीत किया जाता है, जबकि LOCAL को क्लस्टर और डेटा-सेगमेंट के बीच विभाजित किया गया था।

  • एपेंड-ऑन-राइट मोड के कारण LOCAL की तुलना में PLOCAL अधिक टिकाऊ है।

  • PLOCAL में लिखने पर मामूली विवाद ताले हैं, जिसका अर्थ है अधिक संगामिति।

  • PLOCAL मेमोरी मैपिंग तकनीकों (MMap) का उपयोग नहीं करता है, इसलिए व्यवहार अधिक "अनुमानित" है।

अपने स्थानीय भंडारण को नए स्थान पर स्थानांतरित करने के लिए, आपको भंडारण इंजन के रूप में PLOCAL का उपयोग करके डेटाबेस को निर्यात और फिर से आयात करना होगा। निम्नलिखित प्रक्रिया है।

Step 1 - एक नया शेल (लिनक्स / मैक) या एक कमांड प्रॉम्प्ट (विंडोज) खोलें।

Step 2- कंसोल का उपयोग करके डेटाबेस निर्यात करें। डेटाबेस डेमो को निर्यात करने के लिए दिए गए कमांड का पालन करेंdemo.json.gzip फ़ाइल।

$ bin/console.sh (or bin/console.bat under Windows) 
orientdb> CONNECT DATABASE local:/temp/demo admin admin 
orientdb> EXPORT DATABASE /temp/demo.json.gzip 
orientdb> DISCONNECT

Step 3 - स्थानीय फाइल सिस्टम पर, "प्लोकल" इंजन का उपयोग करके एक नया डेटाबेस बनाएं -

orientdb> CREATE DATABASE plocal:/temp/newdb admin admin plocal graph

Step 4 - नए के लिए पुराने डेटाबेस आयात करें।

orientdb> IMPORT DATABASE /temp/demo.json.gzip -preserveClusterIDs=true 
orientdb> QUIT

यदि आप डेटाबेस को उसी JVM में एक्सेस करते हैं, तो URL को "स्थानीय:" से "प्लोकल:" में बदलना याद रखें

ग्राफ़ को रिडबैग पर माइग्रेट करें

OrientDB 1.7 के रूप में, RidBag एक डिफ़ॉल्ट संग्रह है जो ग्राफ़ में आसन्न संबंधों का प्रबंधन करता है। जबकि MVRB- ट्री द्वारा प्रबंधित पुराने डेटाबेस पूरी तरह से संगत हैं, आप अपने डेटाबेस को और हालिया प्रारूप में अपडेट कर सकते हैं।

आप अपने ग्राफ़ को कंसोल के माध्यम से या का उपयोग करके अपग्रेड कर सकते हैं ORidBagMigration कक्षा।

  • डेटाबेस कनेक्ट से कनेक्ट करें plocal:databases/<graphdb-name>

  • उन्नत ग्राफ़ कमांड चलाएँ

RDBMS की तरह, OrientDB भी प्रसिद्ध अवधारणाओं, उपयोगकर्ताओं और भूमिकाओं के आधार पर सुरक्षा प्रदान करता है। प्रत्येक डेटाबेस के अपने उपयोगकर्ता होते हैं और प्रत्येक उपयोगकर्ता की एक या अधिक भूमिकाएँ होती हैं। भूमिकाएं काम करने के तरीके और अनुमतियों के समूह का संयोजन हैं।

उपयोगकर्ताओं

डिफ़ॉल्ट रूप से ओरिएंटबीडी सर्वर में सभी डेटाबेस के लिए तीन अलग-अलग उपयोगकर्ताओं को रखता है -

  • Admin - इस उपयोगकर्ता के पास बिना किसी सीमा के डेटाबेस के सभी कार्यों तक पहुंच है।

  • Reader- यह उपयोगकर्ता केवल पढ़ने वाला उपयोगकर्ता है। पाठक डेटाबेस में किसी भी रिकॉर्ड को क्वेरी कर सकता है, लेकिन उन्हें संशोधित या हटा नहीं सकता है। इसकी आंतरिक जानकारी तक कोई पहुंच नहीं है, जैसे कि उपयोगकर्ता और भूमिकाएं।

  • Writer - यह उपयोगकर्ता उपयोगकर्ता रीडर के समान है, लेकिन यह रिकॉर्ड भी बना सकता है, अपडेट कर सकता है और हटा सकता है।

उपयोगकर्ताओं के साथ काम करना

जब आप किसी डेटाबेस से जुड़े होते हैं, तो आप डेटाबेस के वर्तमान उपयोगकर्ताओं का उपयोग करके क्वेरी कर सकते हैं SELECT पर सवाल OUser कक्षा।

orientdb> SELECT RID, name, status FROM OUser

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

---+--------+--------+-------- 
#  | @CLASS | name   | status 
---+--------+--------+-------- 
0  | null   | admin  | ACTIVE 
1  | null   | reader | ACTIVE 
2  | null   | writer | ACTIVE 
---+--------+--------+-------- 
3 item(s) found. Query executed in 0.005 sec(s).

एक नया उपयोगकर्ता बनाना

एक नया उपयोगकर्ता बनाने के लिए, INSERT कमांड का उपयोग करें। याद रखें, ऐसा करने के लिए, आपको स्थिति सक्रिय करने के लिए सेट करना होगा और इसे एक मान्य भूमिका देनी होगी।

orientdb> INSERT INTO OUser SET 
               name = 'jay', 
               password = 'JaY',
               status = 'ACTIVE',
               roles = (SELECT FROM ORole WHERE name = 'reader')

उपयोगकर्ताओं को अद्यतन करना

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

orientdb> UPDATE OUser SET name = 'jay' WHERE name = 'reader'

उसी तरह, आप उपयोगकर्ता के लिए पासवर्ड भी बदल सकते हैं।

orientdb> UPDATE OUser SET password = 'hello' WHERE name = 'reader'

OrientDB पासवर्ड को हैश फॉर्मेट में सेव करता है। ट्रिगरOUserTrigger रिकॉर्ड सहेजने से पहले पारदर्शी रूप से पासवर्ड एन्क्रिप्ट करता है।

उपयोगकर्ताओं को अक्षम करना

उपयोगकर्ता को अक्षम करने के लिए, अपनी स्थिति को सक्रिय से SUSPENDED पर स्विच करने के लिए उपयोग करें। उदाहरण के लिए, यदि आप व्यवस्थापक को छोड़कर सभी उपयोगकर्ताओं को अक्षम करना चाहते हैं, तो निम्न कमांड का उपयोग करें -

orientdb> UPDATE OUser SET status = 'SUSPENDED' WHERE name <> 'admin'

भूमिकाएँ

एक भूमिका यह निर्धारित करती है कि उपयोगकर्ता किसी संसाधन के खिलाफ कौन से ऑपरेशन कर सकता है। मुख्य रूप से, यह निर्णय कार्य मोड और नियमों पर निर्भर करता है। कार्य मोड के आधार पर, नियम स्वयं अलग तरीके से काम करते हैं।

भूमिका के साथ काम करना

जब आप डेटाबेस से जुड़े होते हैं, तो आप डेटाबेस का उपयोग करके वर्तमान भूमिकाओं को क्वेरी कर सकते हैं SELECT पर सवाल ORole कक्षा।

orientdb> SELECT RID, mode, name, rules FROM ORole

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

--+------+----+--------+------------------------------------------------------- 
# |@CLASS|mode| name   | rules 
--+------+----+--------+------------------------------------------------------- 
0 | null | 1  | admin  | {database.bypassRestricted = 15} 
1 | null | 0  | reader | {database.cluster.internal = 2, database.cluster.orole = 0... 
2 | null | 0  | writer | {database.cluster.internal = 2, database.cluster.orole = 0... 
--+------+----+--------+------------------------------------------------------- 
3 item(s) found.  Query executed in 0.002 sec(s).

नई भूमिकाएँ बनाना

एक नई भूमिका बनाने के लिए, INSERT स्टेटमेंट का उपयोग करें।

orientdb> INSERT INTO ORole SET name = 'developer', mode = 0

मोड्स के साथ काम करना

जहां नियम यह निर्धारित करते हैं कि कुछ भूमिकाओं से संबंधित उपयोगकर्ता डेटाबेस पर क्या कर सकते हैं, काम करने के तरीके यह निर्धारित करते हैं कि कैसे ओरिएंटबीडी इन नियमों की व्याख्या करता है। दो प्रकार के कार्य मोड हैं, 1 और 0 द्वारा निर्दिष्ट।

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

  • Deny All But (Rules)- डिफ़ॉल्ट रूप से यह मोड कुछ नहीं की अनुमति देता है। नियमों का उपयोग करके इसे अपवाद निर्दिष्ट करें। यदि OrientDB एक अनुरोधित संसाधन के लिए नियम पाता है, तो यह उपयोगकर्ता को ऑपरेशन को निष्पादित करने की अनुमति देता है। सभी क्लासिक उपयोगकर्ताओं के लिए डिफ़ॉल्ट के रूप में इस मोड का उपयोग करें। डिफ़ॉल्ट भूमिकाएं, पाठक और लेखक, इस मोड का उपयोग करते हैं। यह डेटाबेस में 0 के रूप में लिखा गया है।

ओरिएंटबैंक एक वेब यूआई प्रदान करता है जो जीयूआई के माध्यम से डेटाबेस संचालन करता है। यह अध्याय OrientDB में उपलब्ध विभिन्न विकल्पों की व्याख्या करता है।

स्टूडियो होमपेज

स्टूडियो ओरिएंटबीडी के प्रशासन के लिए एक वेब इंटरफ़ेस है जो ओरिएंटबीडी वितरण के साथ बंडल में आता है।

सबसे पहले, आपको निम्न कमांड का उपयोग करके ओरिएंटबीडी सर्वर शुरू करने की आवश्यकता है।

$ server.sh

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

http://localhost:2480

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

मौजूदा डेटाबेस से कनेक्ट करें

लॉगिन करने के लिए, डेटाबेस सूची से एक डेटाबेस का चयन करें और किसी भी डेटाबेस उपयोगकर्ता का उपयोग करें। डिफ़ॉल्ट रूप से (उपयोगकर्ता नाम / पासवर्ड)reader/reader डेटाबेस से रिकॉर्ड पढ़ सकते हैं, writer/writer रिकॉर्ड पढ़ सकते हैं, बना सकते हैं, अपडेट कर सकते हैं और हटा सकते हैं admin/admin सभी अधिकार हैं।

मौजूदा डेटाबेस को छोड़ें

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

फिर "ड्रॉप डेटाबेस" बटन पर क्लिक करें। आप में सर्वर क्रेडेंशियल्स पा सकते हैं$ORIENTDB_HOME/config/orientdb-server-config.xml फ़ाइल।

<users> 
   <user name = "root" password = "pwd" resources = "*" /> 
</users>

एक नया डेटाबेस बनाएँ

एक नया डेटाबेस बनाने के लिए, होमपेज से "न्यू डीबी" बटन पर क्लिक करें।

नया डेटाबेस बनाने के लिए निम्नलिखित जानकारी आवश्यक है -

  • डेटाबेस नाम
  • डेटाबेस प्रकार (दस्तावेज़ / ग्राफ़)
  • भंडारण प्रकार (प्लोकल / मेमोरी)
  • सर्वर उपयोगकर्ता
  • सर्वर का पासवर्ड

आप में सर्वर क्रेडेंशियल्स पा सकते हैं $ORIENTDB_HOME/config/orientdbserver-config.xml फ़ाइल।

<users> 
   <user name = "root" password = "pwd" resources = "*" /> 
</users>

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

एक क्वेरी निष्पादित करें

स्टूडियो समर्थित उन भाषाओं के बीच ऑटो पहचान को भाषा का समर्थन करता है: SQL और Gremlin। लिखते समय, ऑटो-पूर्ण सुविधा का उपयोग करके दबाएंCtrl + Space

निम्नलिखित शॉर्टकट क्वेरी संपादक में उपलब्ध हैं -

  • Ctrl + Return - क्वेरी निष्पादित करने के लिए या बस क्लिक करें Run बटन।

  • Ctrl/Cmd + Z - परिवर्तन पूर्ववत करने के लिए।

  • Ctrl/Cmd + Shift + Z - परिवर्तन को फिर से करना।

  • Ctrl/Cmd + F - संपादक में खोज करने के लिए।

  • Ctrl/Cmd + / - एक टिप्पणी टॉगल करें।

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

किसी भी क्लिक करके @rid परिणाम सेट में मूल्य, आप दस्तावेज़ संपादन मोड में जाएंगे यदि रिकॉर्ड एक दस्तावेज़ है, अन्यथा आप शीर्ष संपादन में जाएंगे।

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

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

वर्टेक्स संपादित करें

ग्राफ़ के शीर्ष को संपादित करने के लिए, ग्राफ़ अनुभाग पर जाएँ। फिर निम्नलिखित क्वेरी चलाएँ।

Select From Customer

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

विशेष शीर्ष पर संपादन प्रतीक का चयन करें। आपको निम्न स्क्रीन मिलेगी जिसमें शीर्ष को संपादित करने के विकल्प हैं।

स्कीमा मैनेजर

OrientDB स्कीमा-कम मोड, स्कीमा मोड या दोनों के मिश्रण में काम कर सकता है। यहां हम स्कीमा मोड पर चर्चा करेंगे। वेब UI के शीर्ष पर स्कीमा अनुभाग पर क्लिक करें। आपको निम्न स्क्रीनशॉट मिलेगा।

एक नई कक्षा बनाएँ

एक नया वर्ग बनाने के लिए, बस क्लिक करें New Classबटन। निम्न स्क्रीनशॉट दिखाई देगा। आपको निम्न जानकारी प्रदान करनी होगी जैसा कि नई कक्षा बनाने के लिए स्क्रीनशॉट में दिखाया गया है।

सभी सूचकांक देखें

जब आप अपने डेटाबेस में बनाए गए सभी इंडेक्स का अवलोकन करना चाहते हैं, तो स्कीमा यूआई में सभी इंडेक्स बटन पर क्लिक करें। यह अनुक्रमणिका (नाम, प्रकार, गुण, आदि) के बारे में कुछ जानकारी के लिए एक त्वरित पहुँच प्रदान करेगा और आप उन्हें यहाँ से ड्रॉप या पुनर्निर्माण कर सकते हैं।

कक्षा संपादित करें

स्कीमा अनुभाग पर किसी भी वर्ग पर क्लिक करें, आपको निम्न स्क्रीनशॉट मिलेगा।

कक्षा को संपादित करते समय, आप एक संपत्ति जोड़ सकते हैं या एक नया सूचकांक जोड़ सकते हैं।

एक संपत्ति जोड़ें

प्रॉपर्टी जोड़ने के लिए न्यू प्रॉपर्टी बटन पर क्लिक करें। आपको निम्न स्क्रीनशॉट मिलेगा।

आपको संपत्ति जोड़ने के लिए स्क्रीनशॉट में दिखाए अनुसार निम्नलिखित विवरण प्रदान करना होगा।

एक सूचकांक जोड़ें

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

ग्राफ संपादक

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

ग्राफ़ क्षेत्र को पॉप्युलेट करने के लिए, क्वेरी संपादक में एक क्वेरी टाइप करें या कार्यक्षमता का उपयोग करें ब्राउज़ यूआई से ग्राफ़ पर भेजें।

कार्यक्षेत्र जोड़ें

अपने ग्राफ़ डेटाबेस में और ग्राफ़ कैनवास क्षेत्र में एक नया वर्टेक्स जोड़ने के लिए, आपको बटन दबाना होगा Add Vertex। यह ऑपरेशन दो चरणों में किया जाता है।

पहले चरण में, आपको नए वर्टेक्स के लिए वर्ग चुनना होगा और फिर अगला क्लिक करें।

दूसरे चरण में, आपको नए शीर्ष के फ़ील्ड मान सम्मिलित करने होंगे। आप कस्टम फ़ील्ड भी जोड़ सकते हैं क्योंकि OrientDB स्कीमा-कम मोड का समर्थन करता है। नए शीर्ष को स्थिर रखने के लिए, 'परिवर्तन सहेजें' पर क्लिक करें और शीर्ष को डेटाबेस में सहेजा जाएगा और कैनवास क्षेत्र में जोड़ा जाएगा।

कार्यक्षेत्र हटाएं

जिस वर्टेक्स को आप डिलीट करना चाहते हैं, उस पर क्लिक करके सर्कुलर मेन्यू खोलें। अधिक प्रविष्टि (...) के लिए माउस को मँडरा कर सबमेनू खोलें और फिर ट्रैश आइकन पर क्लिक करें।

कैनवस से वर्टिस निकालें

गोलाकार मेनू खोलें, उप-मेनू को माउस से मेनू प्रविष्टि में अधिक घुमाकर खोलें (...) और फिर इरेज़र आइकन पर क्लिक करें।

कार्यक्षेत्र का निरीक्षण करें

यदि आप वर्टेक्स प्रॉपर्टी पर एक त्वरित नज़र डालना चाहते हैं, तो नेत्र आइकन पर क्लिक करें।

सुरक्षा

स्टूडियो 2.0 में नया सुरक्षा प्रबंधन शामिल है, जहाँ आप उपयोगकर्ताओं और रोल्स को चित्रमय तरीके से प्रबंधित कर सकते हैं।

उपयोगकर्ताओं

डेटाबेस उपयोगकर्ताओं को प्रबंधित करने के लिए आप निम्नलिखित क्रियाएं कर सकते हैं -

  • उपयोगकर्ता खोजें
  • उपयोगकर्ता जोड़ें
  • उपयोगकर्ता हटाएं
  • उपयोगकर्ता संपादित करें: भूमिकाएँ नाम, स्थिति और पासवर्ड के लिए लाइन में संपादित की जा सकती हैं, क्लिक करें Edit बटन

उपयोगकर्ता जोड़ें

एक नया उपयोगकर्ता जोड़ने के लिए, पर क्लिक करें Add User बटन, नए उपयोगकर्ता (नाम, पासवर्ड, स्थिति, भूमिका) के लिए जानकारी को पूरा करें और फिर नए उपयोगकर्ता को डेटाबेस में जोड़ने के लिए सहेजें।

भूमिकाएँ

आप डेटाबेस भूमिकाओं को प्रबंधित करने के लिए निम्नलिखित क्रियाएं कर सकते हैं -

  • भूमिका खोजें
  • भूमिका जोड़ें
  • भूमिका हटाएँ
  • भूमिका संपादित करें

भूमिका जोड़ें

एक नया उपयोगकर्ता जोड़ने के लिए, पर क्लिक करें Add Role बटन, नई भूमिका (नाम, मूल भूमिका, मोड) के लिए जानकारी पूर्ण करें और फिर डेटाबेस में नई भूमिका जोड़ने के लिए सहेजें।

भूमिका में नियम जोड़ें

चयनित भूमिका के लिए एक नया सुरक्षा नियम जोड़ने के लिए, पर क्लिक करें Add Ruleबटन। यह आपसे उस संसाधन की स्ट्रिंग पूछेगा जिसे आप सुरक्षित करना चाहते हैं। फिर आप नए बनाए गए संसाधन पर CRUD अनुमतियों को कॉन्फ़िगर कर सकते हैं।

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

सबसे पहले, हमें JDBC ड्राइवर डाउनलोड करना होगा। निम्नलिखित लिंक पर जाएँhttps://code.google.com/archive/p/orient/downloads ओरिएंटबीडी-जेडडीबीसी डाउनलोड करने के लिए।

OrientDB-jdbc कनेक्टिविटी प्राप्त करने के लिए मूल पाँच चरण निम्नलिखित हैं।

  • लोड JDBC ड्राइवर
  • कनेक्शन बनाएँ
  • कथन बनाएँ
  • एक्सट्यूट स्टेटमेंट
  • निकट संबंध

उदाहरण

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

अनु क्रमांक। कार्यक्षेत्र नाम प्रकार
1 ईद पूर्णांक
2 नाम तार
3 वेतन पूर्णांक
4 शामिल होने की तारीख दिनांक

आप निम्न आदेशों को निष्पादित करके एक स्कीमा (तालिका) बना सकते हैं।

CREATE DATABASE PLOCAL:/opt/orientdb/databases/testdb 
CREATE CLASS Employee 
CREATE PROPERTY Customer.id integer 
CREATE PROPERTY Customer.name String 
CREATE PROPERTY Customer.salary integer 
CREATE PROPERTY Customer.join_date date

सभी आदेशों को निष्पादित करने के बाद, आपको निम्न फ़ील्ड, आईडी, आयु और कर्मचारी के साथ कर्मचारी नाम के साथ कर्मचारी तालिका मिलेगी।

निम्न कोड में सहेजें OrientJdbcDemo.java फ़ाइल।

import com.orientechnologies.common.log.OLogManager; 
import com.orientechnologies.orient.core.db.document.ODatabaseDocumentTx; 
import org.junit.After; 
import org.junit.Before; 
import org.junit.BeforeClass;
  
import java.io.File; 
import java.sql.DriverManager; 
import java.util.Properties;
  
import static com.orientechnologies.orient.jdbc.OrientDbCreationHelper.createSchemaDB; 
import static com.orientechnologies.orient.jdbc.OrientDbCreationHelper.loadDB; 
import static java.lang.Class.forName;
  
public abstract class OrientJdbcDemo {
  
   protected OrientJdbcConnection conn; 
   
   public static void main(String ar[]){ 
       
      //load Driver 
      forName(OrientJdbcDriver.class.getName()); 
      String dbUrl = "memory:testdb"; 
      ODatabaseDocumentTx db = new ODatabaseDocumentTx(dbUrl); 
      String username = "admin"; 
      String password = "admin"; 
      createSchemaDB(db); 
      loadDB(db, 20); 
      dbtx.create(); 
       
      //Create Connection 
      Properties info = new Properties(); 
      info.put("user", username); 
      info.put("password", password); 
      conn = (OrientJdbcConnection) DriverManager.getConnection("jdbc:orient:" + dbUrl, info); 
	  
      //create and execute statement 
      Statement stmt = conn.createStatement(); 
      int updated = stmt.executeUpdate("INSERT into emplyoee 
         (intKey, text, salary, date) values ('001','satish','25000','" 
         + date.toString() + "')"); 
      int updated = stmt.executeUpdate("INSERT into emplyoee 
         (intKey, text, salary, date) values ('002','krishna','25000','" 
         + date.toString() + "')"); 
      System.out.println("Records successfully inserted"); 
	  
      //Close Connection 
      if (conn != null && !conn.isClosed()) 
         conn.close(); 
   } 
}

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

$ javac –classpath:.:orientdb-jdbc-1.0-SNAPSHOT.jar OrientJdbcDemo.java $ java –classpath:.:orientdb-jdbc-1.0-SNAPSHOT.jar OrientJdbcDemo

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

Records Successfully Inserted

पायथन के लिए ओरिएंटबीडी ड्राइवर बाइनरी प्रोटोकॉल का उपयोग करता है। PyOrient git हब प्रोजेक्ट नाम है जो OrientDB को Python से जोड़ने में मदद करता है। यह ओरिएंटबीडी संस्करण 1.7 और बाद के संस्करण के साथ काम करता है।

निम्न आदेश का उपयोग PyOrient को स्थापित करने के लिए किया जाता है।

pip install pyorient

आप नाम की स्क्रिप्ट फ़ाइल का उपयोग कर सकते हैं demo.py निम्नलिखित कार्य करने के लिए -

  • एक ग्राहक उदाहरण बनाएँ एक कनेक्शन बनाने का मतलब है।

  • नाम बनाएं DB DB_Demo

  • Open DB नाम DB_Demo।

  • वर्ग my_class बनाएं।

  • गुण आईडी, और नाम बनाएँ।

  • मेरी कक्षा में रिकॉर्ड डालें।

//create connection 
client = pyorient.OrientDB("localhost", 2424) 
session_id = client.connect( "admin", "admin" ) 
//create a databse 
client.db_create( db_name, pyorient.DB_TYPE_GRAPH, pyorient.STORAGE_TYPE_MEMORY ) 
//open databse 
client.db_open( DB_Demo, "admin", "admin" ) 
//create class 
cluster_id = client.command( "create class my_class extends V" ) 
//create property 
cluster_id = client.command( "create property my_class.id Integer" ) 
cluster_id = client.command( "create property my_class.name String" ) 
//insert record 
client.command("insert into my_class ( 'id','’name' ) values( 1201, 'satish')")

निम्नलिखित कमांड का उपयोग करके उपरोक्त स्क्रिप्ट निष्पादित करें।

$ python demo.py