OrientDB - Guida rapida

OrientDB è un sistema di gestione di database NoSQL open source. NoSQL Databasefornisce un meccanismo per l'archiviazione e il recupero di dati NO-relazione o NON relazionali che si riferiscono a dati diversi da dati tabulari come dati di documenti o dati di grafici. I database NoSQL sono sempre più utilizzati nei Big Data e nelle applicazioni web in tempo reale. I sistemi NoSQL sono talvolta chiamati "Non solo SQL" per sottolineare che possono supportare linguaggi di query simili a SQL.

Anche OrientDB appartiene alla famiglia NoSQL. OrientDB è un database a grafo distribuito di seconda generazione con la flessibilità dei documenti in un prodotto con una licenza open source di Apache 2. C'erano diversi database NoSQL sul mercato prima di OrientDB, uno dei quali era MongoDB.

MongoDB contro OrientDB

MongoDB e OrientDB contengono molte caratteristiche comuni ma i motori sono fondamentalmente diversi. MongoDB è un puro database di documenti e OrientDB è un documento ibrido con motore grafico.

Caratteristiche MongoDB OrientDB
Relationships Utilizza RDBMS JOINS per creare relazioni tra entità. Ha un costo di runtime elevato e non si adatta all'aumento della scala del database. Incorpora e collega documenti come database relazionali. Utilizza collegamenti diretti e super veloci presi dal mondo del database a grafo.
Fetch Plan Costose operazioni di JOIN. Restituisce facilmente un grafico completo con documenti interconnessi.
Transactions Non supporta le transazioni ACID, ma supporta le operazioni atomiche. Supporta transazioni ACID e operazioni atomiche.
Query language Ha una propria lingua basata su JSON. Il linguaggio delle query è basato su SQL.
Indexes Utilizza l'algoritmo B-Tree per tutti gli indici. Supporta tre diversi algoritmi di indicizzazione in modo che l'utente possa ottenere le migliori prestazioni.
Storage engine Utilizza la tecnica di mappatura della memoria. Utilizza il nome del motore di archiviazione LOCAL e PLOCAL.

OrientDB è il primo DBMS NoSQL open source multi-modello che riunisce la potenza dei grafici e la flessibilità dei documenti in un database operativo scalabile ad alte prestazioni.

Il file di installazione di OrientDB è disponibile in due edizioni:

  • Community Edition - L'edizione della comunità di OrientDB è rilasciata da Apache con licenza 0.2 come open source

  • Enterprise Edition- OrientDB Enterprise Edition viene rilasciato come software proprietario, costruito su Community Edition. Serve come estensione dell'edizione della community.

Questo capitolo spiega la procedura di installazione di OrientDB community edition perché è open source.

Prerequisiti

Entrambe le edizioni community ed Enterprise possono essere eseguite su qualsiasi sistema operativo che implementa la Java Virtual Machine (JVM). OrientDB richiede Java con 1.7 o versione successiva.

Utilizzare i seguenti passaggi per scaricare e installare OrientDB nel sistema.

Passaggio 1: scaricare il file di installazione binaria OrientDB

OrientDB viene fornito con un file di installazione integrato per installare il database sul sistema. Fornisce diversi pacchetti binari precompilati (pacchetti tarati o compressi) per diversi sistemi operativi. È possibile scaricare i file OrientDB dal collegamento Scarica OrientDB .

Lo screenshot seguente mostra la pagina di download di OrientDB. È possibile scaricare il file compresso o tarato facendo clic sull'icona del sistema operativo appropriato.

Al momento del download, otterrai il pacchetto binario nel tuo Downloads cartella.

Passaggio 2: estrai e installa OrientDB

Di seguito è riportata la procedura per estrarre e installare OrientDB per diversi sistemi operativi.

In Linux

Dopo il download otterrai orientdb-community-2.1.9.tar.gz file nel tuo Downloadscartella. È possibile utilizzare il seguente comando per estrarre il file tarato.

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

È possibile utilizzare il seguente comando per spostare tutti i file della libreria OrientDB da orientdbcommunity-2.1.9 to /opt/orientdb/directory. Qui stiamo usando il comando super utente (sudo) quindi devi fornire la password del super utente per eseguire il seguente comando.

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

È possibile utilizzare i seguenti comandi per registrare il file orientdb comando e il server Orient.

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

In Windows

  • Dopo il download otterrai orientdb-community-2.1.9.zip file nel tuo Downloadscartella. Estrai il file zip utilizzando l'estrattore zip.

  • Sposta la cartella estratta nel file C:\ directory.

  • Creare due variabili ambientali ORIENTDB_HOME e variabili PATH con i seguenti valori forniti.

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

Passaggio 3: configurazione del server OrientDB come servizio

Seguendo i passaggi precedenti è possibile utilizzare la versione desktop di OrientDB. È possibile avviare il server di database OrientDB come servizio utilizzando i seguenti passaggi. La procedura è diversa, a seconda del sistema operativo.

In Linux

OrientDB fornisce un file di script denominato orientdb.shper eseguire il database come un demone. Puoi trovarlo nella directory bin / della directory di installazione di OrientDB che è $ ORIENTDB_HOME / bin / orientdb.sh.

Prima di eseguire il file di script, devi modificare orientdb.shfile per la definizione di due variabili. Uno èORIENTDB_DIR che definisce il percorso della directory di installazione (/opt/orientdb) e il secondo è ORIENTDB_USER che definisce il nome utente per il quale si desidera eseguire OrientDB come segue.

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

Usa il seguente comando per copiare orientdb.sh file in /etc/init.d/directory per inizializzare ed eseguire lo script. Qui stiamo usando il comando super utente (sudo) quindi devi fornire la password del super utente per eseguire il seguente comando.

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

Utilizzare il seguente comando per copiare il file console.sh dalla directory di installazione di OrientDB, ovvero $ORIENTDB_HOME/bin alla directory bin di sistema che è /usr/bin per accedere alla console di Orient DB.

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

Utilizzare il seguente comando per avviare il server di database ORIENTDB come servizio. Qui devi fornire la password del rispettivo utente che hai menzionato nel file orientdb.sh per avviare il server.

$ service orientdb start

Utilizzare il seguente comando per sapere su quale PID è in esecuzione il daemon del server OrientDB.

$ service orientdb status

Utilizzare il seguente comando per arrestare il daemon del server OrientDB. Qui devi fornire la password del rispettivo utente, che hai menzionato nel file orientdb.sh per arrestare il server.

$ service orientdb stop

In Windows

OrientDB è un'applicazione server, quindi deve eseguire diverse attività prima di avviare l'arresto del processo della macchina virtuale Java. Se vuoi chiudere manualmente il server OrientDB, devi eseguireshutdown.batfile. Ma le istanze del server non si arrestano correttamente, quando il sistema si spegne improvvisamente senza eseguire lo script precedente. Vengono chiamati i programmi controllati dal sistema operativo con una serie di segnali specificatiservices in Windows.

Dobbiamo usare Apache Common Daemonche consentono agli utenti Windows di eseguire il wrapping delle applicazioni Java come servizio Windows. Di seguito è riportata la procedura per scaricare e registrare il demone comune di Apache.

  • Fare clic sul collegamento seguente per Apache Common Daemons per Windows .

  • Clicca su common-daemon-1.0.15-bin-windows scaricare.

  • Decomprimere il file common-daemon-1.0.15-bin-windowsdirectory. Dopo l'estrazione troveraiprunsrv.exe e prunmgr.exefile all'interno della directory. In quelli -

    • prunsrv.exe file è un'applicazione di servizio per l'esecuzione di applicazioni come servizi.

    • prunmgr.exe file è un'applicazione utilizzata per il monitoraggio e la configurazione dei servizi di Windows.

  • Vai alla cartella di installazione di OrientDB → crea una nuova directory e chiamala servizio.

  • Copia il file prunsrv.exe e prunmgr .exe incollalo nella directory del servizio.

  • Per configurare OrientDB come servizio Windows, è necessario eseguire un breve script che utilizza prusrv.exe come servizio Windows.

  • Prima di definire i servizi di Windows, è necessario rinominare prunsrv e prunmgr in base al nome del servizio. Ad esempio, OrientDBGraph e OrientDBGraphw rispettivamente. Qui OrientDBGraph è il nome del servizio.

  • Copia il seguente script nel file denominato installService.bat e posizionalo in %ORIENTDB_HOME%\service\ directory.

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

Lo script richiede due parametri:

  • La posizione di jvm.dll, ad esempio C: \ ProgramFiles \ java \ jdk1.8.0_66 \ jre \ bin \ server \ jvm.dll

  • La posizione dell'installazione di OrientDB, ad esempio, C: \ orientdb-community-2.1.9

  • Il servizio viene installato quando si esegue il file OrientDBGraph.exe (Original prunsrv) e si fa doppio clic su di esso.

  • Utilizzare il seguente comando per installare i servizi in 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

Apri i servizi di Task Manager, troverai la seguente schermata con il nome del servizio registrato.

Passaggio 4: verifica dell'installazione di OrientDB

Questo passaggio verifica l'installazione del server di database OrientDB utilizzando i seguenti passaggi.

  • Avvia il server.
  • Avvia la console.
  • Gestisci lo studio.

Questo è unico in base al sistema operativo.

In Linux

Seguire la procedura indicata per verificare l'installazione di OrientDB in Linux.

Running the server - È possibile utilizzare il seguente comando per avviare il server.

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

Oppure è possibile utilizzare il seguente comando per avviare il server OrientDB come daemon UNIX.

$ service orientdb start

Se è installato correttamente, riceverai il seguente output.

.                                           
          .`        `                                  
          ,      `:.                                   
         `,`    ,:`                                    
         .,.   :,,                                     
         .,,  ,,,                                      
    .    .,.:::::  ````                                 :::::::::     :::::::::    
    ,`   .::,,,,::.,,,,,,`;;                      .:    ::::::::::    :::    :::   
    `,.  ::,,,,,,,:.,,.`  `                       .:    :::      :::  :::     :::  
     ,,:,:,,,,,,,,::.   `        `         ``     .:    :::      :::  :::     :::  
      ,,:.,,,,,,,,,: `::, ,,   ::,::`   : :,::`  ::::   :::      :::  :::    :::   
       ,:,,,,,,,,,,::,:   ,,  :.    :   ::    :   .:    :::      :::  :::::::      
        :,,,,,,,,,,:,::   ,,  :      :  :     :   .:    :::      :::  :::::::::    
  `     :,,,,,,,,,,:,::,  ,, .::::::::  :     :   .:    :::      :::  :::     :::  
  `,...,,:,,,,,,,,,: .:,. ,, ,,         :     :   .:    :::      :::  :::     ::: 
    .,,,,::,,,,,,,:  `: , ,,  :     `   :     :   .:    :::      :::  :::     :::  
      ...,::,,,,::.. `:  .,,  :,    :   :     :   .:    :::::::::::   :::     :::  
           ,::::,,,. `:   ,,   :::::    :     :   .:    :::::::::     ::::::::::   
           ,,:` `,,.                                   
          ,,,    .,`                                   
         ,,.     `,                                          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 - È possibile utilizzare il seguente comando per eseguire OrientDB nella console.

$ orientdb

Se è installato correttamente, riceverai il seguente output.

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 - Dopo aver avviato il server è possibile utilizzare il seguente URL (http://localhost:2480/) sul tuo browser. Otterrai il seguente screenshot.

In Windows

Seguire la procedura indicata per verificare l'installazione di OrientDB in Windows.

Running the server - È possibile utilizzare il seguente comando per avviare il server.

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

Se è installato correttamente, riceverai il seguente output.

.                                           
          .`        `                                  
          ,      `:.                                   
         `,`    ,:`                                    
         .,.   :,,    
		 .,,  ,,,                                      
    .    .,.:::::  ````                                 :::::::::     :::::::::    
    ,`   .::,,,,::.,,,,,,`;;                      .:    ::::::::::    :::    :::   
    `,.  ::,,,,,,,:.,,.`  `                       .:    :::      :::  :::     :::  
     ,,:,:,,,,,,,,::.   `        `         ``     .:    :::      :::  :::     :::  
      ,,:.,,,,,,,,,: `::, ,,   ::,::`   : :,::`  ::::   :::      :::  :::    :::   
       ,:,,,,,,,,,,::,:   ,,  :.    :   ::    :   .:    :::      :::  :::::::      
        :,,,,,,,,,,:,::   ,,  :      :  :     :   .:    :::      :::  :::::::::    
  `     :,,,,,,,,,,:,::,  ,, .::::::::  :     :   .:    :::      :::  :::     :::  
  `,...,,:,,,,,,,,,: .:,. ,, ,,         :     :   .:    :::      :::  :::     :::  
    .,,,,::,,,,,,,:  `: , ,,  :     `   :     :   .:    :::      :::  :::     :::  
      ...,::,,,,::.. `:  .,,  :,    :   :     :   .:    :::::::::::   :::     :::  
           ,::::,,,. `:   ,,   :::::    :     :   .:    :::::::::     ::::::::::   
           ,,:` `,,.                                   
          ,,,    .,`                                   
         ,,.     `,                                          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 - È possibile utilizzare il seguente comando per eseguire OrientDB nella console.

> %ORIENTDB_HOME%\bin\console.bat

Se è installato correttamente, riceverai il seguente output.

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 - Dopo aver avviato il server è possibile utilizzare il seguente URL (http://localhost:2480/) sul tuo browser. Otterrai il seguente screenshot.

La caratteristica principale di OrientDB è di supportare oggetti multi-modello, cioè supporta diversi modelli come Documento, Grafico, Chiave / Valore e Oggetto Reale. Contiene un'API separata per supportare tutti questi quattro modelli.

Modello di documento

La terminologia Document model appartiene al database NoSQL. Significa che i dati sono memorizzati nei Documenti e il gruppo di Documenti viene chiamato comeCollection. Tecnicamente, documento indica un insieme di coppie chiave / valore o indicato anche come campi o proprietà.

OrientDB utilizza concetti quali classi, cluster e collegamento per archiviare, raggruppare e analizzare i documenti.

La tabella seguente illustra il confronto tra modello relazionale, modello di documento e modello di documento OrientDB -

Modello relazionale Modello di documento Modello di documento OrientDB
tavolo Collezione Classe o cluster
Riga Documento Documento
Colonna Coppia chiave / valore Campo documento
Relazione Non disponibile Link

Modello grafico

Una struttura dati a grafo è un modello di dati che può memorizzare i dati sotto forma di vertici (nodi) interconnessi da bordi (archi). L'idea del database di grafici di OrientDB è nata dal grafico delle proprietà. Il vertice e il bordo sono i principali artefatti del modello Graph. Contengono le proprietà che possono farli sembrare simili ai documenti.

La tabella seguente mostra un confronto tra il modello di grafico, il modello di dati relazionali e il modello di grafico OrientDB.

Modello relazionale Modello grafico Modello grafico OrientDB
tavolo Classe vertice e bordo Classe che estende "V" (per Vertex) ed "E" (per Edges)
Riga Vertice Vertice
Colonna Proprietà Vertice e Bordo Proprietà Vertice e Bordo
Relazione Bordo Bordo

Il modello chiave / valore

Il modello chiave / valore significa che i dati possono essere archiviati sotto forma di coppia chiave / valore in cui i valori possono essere di tipo semplice e complesso. Può supportare documenti ed elementi grafici come valori.

La tabella seguente illustra il confronto tra modello relazionale, modello chiave / valore e modello chiave / valore OrientDB.

Modello relazionale Modello chiave / valore Modello chiave / valore OrientDB
tavolo Secchio Classe o cluster
Riga Coppia chiave / valore Documento
Colonna Non disponibile Campo del documento o proprietà Vertice / Bordo
Relazione Non disponibile Link

Il modello a oggetti

Questo modello è stato ereditato dalla programmazione e dai supporti orientati agli oggetti Inheritance tra i tipi (i sottotipi estendono i super-tipi), Polymorphism quando fai riferimento a una classe base e Direct binding da / a Oggetti utilizzati nei linguaggi di programmazione.

La tabella seguente illustra il confronto tra modello relazionale, modello a oggetti e modello a oggetti OrientDB.

Modello relazionale Modello a oggetti OrientDB Object Model
tavolo Classe Classe o cluster
Riga Oggetto Documento o vertice
Colonna Proprietà dell'oggetto Campo del documento o proprietà Vertice / Bordo
Relazione Pointer Link

Prima di procedere nel dettaglio, è meglio conoscere la terminologia di base associata a OrientDB. Di seguito sono riportate alcune delle terminologie importanti.

Disco

L'unità più piccola da cui è possibile caricare e memorizzare nel database. I record possono essere memorizzati in quattro tipi.

  • Document
  • Record di byte
  • Vertex
  • Edge

ID record

Quando OrientDB genera un record, il server del database assegna automaticamente un identificatore di unità al record, chiamato RecordID (RID). Il RID è simile a # <cluster>: <position>. <cluster> indica il numero di identificazione del cluster e <position> indica la posizione assoluta del record nel cluster.

Documenti

Il documento è il tipo di record più flessibile disponibile in OrientDB. I documenti sono tipizzati in modo morbido e sono definiti da classi di schemi con vincoli definiti, ma puoi anche inserire il documento senza alcuno schema, cioè supporta anche la modalità senza schema.

I documenti possono essere facilmente gestiti mediante esportazione e importazione in formato JSON. Ad esempio, dai un'occhiata al seguente documento di esempio JSON. Definisce i dettagli del documento.

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

RecordBytes

Il tipo di record è lo stesso del tipo BLOB in RDBMS. OrientDB può caricare e memorizzare il tipo di record del documento insieme ai dati binari.

Vertice

Il database OrientDB non è solo un database di documenti ma anche un database di grafici. I nuovi concetti come Vertex e Edge vengono utilizzati per memorizzare i dati sotto forma di grafico. Nei database a grafo, l'unità di dati più elementare è il nodo, che in OrientDB è chiamato vertice. Il Vertex memorizza le informazioni per il database.

Bordo

Esiste un tipo di record separato chiamato Edge che collega un vertice a un altro. I bordi sono bidirezionali e possono collegare solo due vertici. Esistono due tipi di bordi in OrientDB, uno regolare e un altro leggero.

Classe

La classe è un tipo di modello di dati e il concetto è tratto dal paradigma di programmazione orientata agli oggetti. In base al modello di database dei documenti tradizionale, i dati vengono archiviati sotto forma di raccolta, mentre nel modello di database relazionale i dati vengono archiviati in tabelle. OrientDB segue l'API del documento insieme al paradigma OPPS. Come concetto, la classe in OrientDB ha la relazione più stretta con la tabella nei database relazionali, ma (a differenza delle tabelle) le classi possono essere senza schema, complete di schema o miste. Le classi possono ereditare da altre classi, creando alberi di classi. Ogni classe ha il proprio cluster o cluster, (creati per impostazione predefinita, se nessuno è definito).

Grappolo

Il cluster è un concetto importante che viene utilizzato per archiviare record, documenti o vertici. In parole semplici, Cluster è un luogo in cui viene archiviato un gruppo di record. Per impostazione predefinita, OrientDB creerà un cluster per classe. Tutti i record di una classe vengono archiviati nello stesso cluster con lo stesso nome della classe. È possibile creare fino a 32.767 (2 ^ 15-1) cluster in un database.

La classe CREATE è un comando utilizzato per creare un cluster con un nome specifico. Una volta creato il cluster, è possibile utilizzare il cluster per salvare i record specificando il nome durante la creazione di qualsiasi modello di dati.

Relazioni

OrientDB supporta due tipi di relazioni: referenziata e incorporata. Referenced relationships significa che memorizza il collegamento diretto agli oggetti di destinazione delle relazioni. Embedded relationshipssignifica che memorizza la relazione all'interno del record che la incorpora. Questa relazione è più forte della relazione di riferimento.

Banca dati

Il database è un'interfaccia per accedere alla memoria reale. L'IT comprende concetti di alto livello come query, schemi, metadati, indici e così via. OrientDB fornisce anche più tipi di database. Per ulteriori informazioni su questi tipi, vedere Tipi di database.

OrientDB supporta diversi tipi di dati in modo nativo. Di seguito è riportata la tabella completa sullo stesso.

Sr. No. genere Descrizione
1 Booleano

Gestisce solo i valori True o False.

Java types: java.lang.Boolean

Min: 0

Max: 1

2 Numero intero

Interi con segno a 32 bit.

Java types: java.lang.Interger

Min: -2.147.483.648

Max: +2.147.483.647

3 Corto

Piccoli interi con segno a 16 bit.

Java types: java.lang.short

Min: -32,768

Max: 32,767

4 Lungo

Grandi interi con segno a 64 bit.

Java types: java.lang.Long

Min: -2 63

Max: 2 63 -1

5 Galleggiante

Numeri decimali.

Java types: java.lang.Float

: 2 -149

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

6 Doppio

Numeri decimali con alta precisione.

Java types: Java.lang.Double.

Min: 2-1074

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

7 Appuntamento

Qualsiasi data con la precisione fino a millisecondi.

Java types: java.util.Date

8 Corda

Qualsiasi stringa come sequenza alfanumerica di caratteri.

Java types: java.lang.String

9 Binario

Può contenere qualsiasi valore come matrice di byte.

Java types: byte []

Min: 0

Max: 2.147.483.647

10 Incorporato

Il record è contenuto all'interno del proprietario. Il record contenuto non ha RecordId.

Java types: ORecord

11 Elenco incorporato

I record sono contenuti all'interno del proprietario. I record contenuti non hanno RecordID e sono raggiungibili solo navigando nel record del proprietario.

Java types: Elenca <oggetti>

Min: 0

Max: 41.000.000 di articoli

12 Set incorporato

I record sono contenuti all'interno del proprietario. I record contenuti non hanno RecordId e sono raggiungibili solo navigando nel record del proprietario.

Java types: imposta <oggetti>

Min: 0

Max: 41.000.000 di articoli

13 Mappa incorporata

I record sono contenuti all'interno del proprietario come valori delle voci, mentre le chiavi possono essere solo stringhe. I record contenuti non hanno RecordId e sono raggiungibili solo navigando nel Record proprietario.

Java types: Map <String, ORecord>

Min: 0

Max: 41.000.000 di articoli

14 Link

Collegamento a un altro record. È una comune relazione uno a uno

Java Types: ORID, <? estende ORecord>

Min: 1

Max: 32767: 2 ^ 63-1

15 Elenco dei collegamenti

Collegamenti ad altri record. È una comune relazione uno-a-molti in cui vengono archiviati solo i RecordId.

Java types: List <? Estende ORecord>

Min: 0

Max: 41.000.000 di articoli

16 Set di collegamenti

Collegamenti ad altri record. È una comune relazione uno-a-molti.

Java types: Imposta <? estende ORecord>

Min: 0

Max: 41.000.000 di articoli

17 Mappa del collegamento

Collegamenti ad altri record come valore delle voci, mentre le chiavi possono essere solo stringhe. È una comune relazione uno-a-molti. Vengono memorizzati solo i RecordId.

Java types: Map <String,? estende Record>

Min: 0

Max: 41.000.000 di articoli

18 Byte

Singolo byte. Utile per memorizzare piccoli interi con segno a 8 bit.

Java types: java.lang.Byte

Min: -128

Max: +127

19 Transitorio Qualsiasi valore non memorizzato nel database.
20 Data

Qualsiasi data come anno, mese e giorno.

Java Types: java.util.Date

21 Personalizzato

Utilizzato per memorizzare un tipo personalizzato che fornisce i metodi Marshall e Unmarshall.

Java types: OSerializableStream

Min: 0

Max: X

22 Decimale

Numeri decimali senza arrotondamento.

Java types: java.math.BigDecimal

23 LinkBag

Elenco di RecordIds come RidBag specifico.

Java types: ORidBag

24 Qualunque

Tipo non determinato, utilizzato per specificare raccolte di tipo misto e null.

Nei capitoli seguenti, viene discusso come utilizzare questi tipi di dati in OrientDB.

La console OrientDB è un'applicazione Java creata per funzionare con i database OrientDB e le istanze del server. Esistono diverse modalità di console supportate da OrientDB.

Modalità interattiva

Questa è la modalità di default. Basta avviare la console eseguendo il seguente scriptbin/console.sh (o bin/console.batnei sistemi MS Windows). Assicurati di avere il permesso di esecuzione su di esso.

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

Una volta terminato, la console è pronta per accettare i comandi.

Modalità batch

Per eseguire comandi in modalità batch, eseguire quanto segue bin/console.sh (o bin/console.bat nei sistemi MS Windows) script passando tutti i comandi separati da punto e virgola ";".

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

Oppure chiama lo script della console passando il nome del file in formato testo contenente l'elenco dei comandi da eseguire. I comandi devono essere separati dal punto e virgola ";".

Esempio

Command.txt contiene l'elenco dei comandi che si desidera eseguire tramite la console OrientDB. Il seguente comando accetta il batch di comandi dal file command.txt.

orientdb> console.bat commands.txt

In modalità batch, è possibile ignorare gli errori per consentire allo script di continuare l'esecuzione impostando la variabile "ignoreErrors" su true.

orientdb> set ignoreErrors true

Abilita Echo

Quando si eseguono i comandi della console nella pipeline, sarà necessario visualizzarli. Abilita l '"eco" dei comandi impostandola come proprietà all'inizio. Di seguito è riportata la sintassi per abilitare la proprietà echo nella console di OrientDB.

orientdb> set echo true

Il riferimento SQL del database OrientDB fornisce diversi comandi per creare, modificare e rilasciare database.

La seguente dichiarazione è una sintassi di base del comando Crea database.

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

Di seguito sono riportati i dettagli sulle opzioni nella sintassi precedente.

<database-url>- Definisce l'URL del database. L'URL contiene due parti, una è <mode> e la seconda è <path>.

<mode> - Definisce la modalità, ovvero modalità locale o modalità remota.

<path> - Definisce il percorso del database.

<user> - Definisce l'utente che si desidera connettere al database.

<password> - Definisce la password per la connessione al database.

<storage-type>- Definisce i tipi di archiviazione. Puoi scegliere tra PLOCAL e MEMORY.

Esempio

È possibile utilizzare il seguente comando per creare un database locale denominato demo.

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

Se il database viene creato correttamente, otterrai il seguente output.

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

orientdb {db = demo}>

Il database è uno dei modelli di dati importanti con diversi attributi che è possibile modificare in base alle proprie esigenze.

La seguente dichiarazione è la sintassi di base del comando Alter Database.

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

Dove <attribute-name> definisce l'attributo che si desidera modificare e <attributevalue> definisce il valore che si desidera impostare per quell'attributo.

La tabella seguente definisce l'elenco degli attributi supportati per la modifica di un database.

Sr.No. nome attributo Descrizione
1 STATO Definisce lo stato del database tra diversi attributi.
2 IMPORTAZIONE Imposta lo stato di importazione.
3 DEFAULTCLUSTERID Imposta il cluster predefinito utilizzando l'ID. Di default è 2.
4 FORMATO DATA Imposta il formato della data particolare come predefinito. Per impostazione predefinita è "aaaa-MM-gg".
5 DATETIMEFORMAT Imposta il formato della data e dell'ora come predefinito. Per impostazione predefinita è "aaaa-MM-gg HH: mm: ss".
6 FUSO ORARIO Imposta il fuso orario specifico. Per impostazione predefinita, è il fuso orario predefinito di Java Virtual Machine (JVM).
7 LOCALECOUNTRY Imposta il paese della lingua predefinita. Per impostazione predefinita, è il paese della locale predefinita di JVM. Ad esempio: "GB".
8 LOCALELANGUAGE Imposta la lingua locale predefinita. Per impostazione predefinita, è la lingua locale predefinita di JVM. Ad esempio: "en".
9 CHARSET Imposta il tipo di set di caratteri. Per impostazione predefinita, è il set di caratteri predefinito di JVM. Ad esempio: "utf8".
10 SELEZIONE DEL CLUSTER Imposta la strategia predefinita utilizzata per la selezione del cluster. Queste strategie vengono create insieme alla creazione della classe. Le strategie supportate sono predefinite, roundrobin e bilanciate.
11 MINIMUMCLUSTER Imposta il numero minimo di cluster da creare automaticamente quando viene creata una nuova classe. Di default è 1.
12 PERSONALIZZATO Imposta la proprietà personalizzata.
13 CONVALIDA Disabilita o abilita le convalide per l'intero database.

Esempio

Dalla versione di OrientDB-2.2, viene aggiunto il nuovo parser SQL che in alcuni casi non consentirà la sintassi regolare. Pertanto, in alcuni casi dobbiamo disabilitare il nuovo parser SQL (StrictSQL). È possibile utilizzare il seguente comando Alter database per disabilitare il parser StrictSQL.

orientdb> ALTER DATABASE custom strictSQL = false

Se il comando viene eseguito correttamente, otterrai il seguente output.

Database updated successfully

Come RDBMS, anche OrientDB supporta le operazioni di backup e ripristino. Durante l'esecuzione dell'operazione di backup, tutti i file del database corrente verranno salvati in un formato zip compresso utilizzando l'algoritmo ZIP. Questa funzione (backup) può essere utilizzata automaticamente abilitando il plug-in del server di backup automatico.

Fare il backup di un database o esportare un database è lo stesso, tuttavia, in base alla procedura dobbiamo sapere quando usare il backup e quando usare l'esportazione.

Durante il backup, creerà una copia coerente di un database, tutte le ulteriori operazioni di scrittura sono bloccate e in attesa di completare il processo di backup. In questa operazione, creerà un file di backup di sola lettura.

Se è necessaria l'operazione di lettura e scrittura simultanea durante l'esecuzione di un backup, è necessario scegliere di esportare un database invece di eseguire il backup di un database. L'esportazione non blocca il database e consente scritture simultanee durante il processo di esportazione.

La seguente dichiarazione è la sintassi di base del backup del database.

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

Di seguito sono riportati i dettagli sulle opzioni nella sintassi precedente.

<dburl> - L'URL del database in cui si trova il database nella posizione locale o remota.

<user> - Specifica il nome utente per eseguire il backup.

<password> - Fornisce la password per un determinato utente.

<destination> - Posizione del file di destinazione che indica dove archiviare il file zip di backup.

<type>- Tipo di backup opzionale. Ha una delle due opzioni.

  • Predefinito: blocca il database durante il backup.

  • LVM: utilizza lo snapshot di copia su scrittura di LVM in background.

Esempio

Eseguire un backup della demo del database che si trova nel file system locale / opt / orientdb / databases / demo in un file denominato sample-demo.zip e situato nella directory corrente.

È possibile utilizzare il seguente comando per eseguire un backup della demo del database.

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

Utilizzo della console

Lo stesso che puoi fare usando la console OrientDB. Prima di eseguire il backup di un database particolare, devi prima connetterti al database. È possibile utilizzare il seguente comando per connettersi al database denominato demo.

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

Dopo la connessione è possibile utilizzare il seguente comando per eseguire il backup del database in un file denominato "backup-demo.zip" nella directory corrente.

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

Se questo comando viene eseguito correttamente, riceverai alcune notifiche di successo insieme al seguente messaggio.

Backup executed in 0.30 seconds

Come come RDBMS, OrientDB supporta anche l'operazione di ripristino. Solo dalla modalità console è possibile eseguire correttamente questa operazione.

La seguente istruzione è la sintassi di base per il ripristino dell'operazione.

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

Esempio

È necessario eseguire questa operazione solo dalla modalità console. Pertanto, prima devi avviare la console OrientDB utilizzando il seguente comando OrientDB.

$ orientdb

Quindi, connettersi al rispettivo database per ripristinare il backup. È possibile utilizzare il seguente comando per connettersi al database denominato demo.

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

Una volta stabilita la connessione, è possibile utilizzare il seguente comando per ripristinare il backup dal file "backup-demo.zip". Prima di eseguire, assicurati che il file backup-demo.zip sia posizionato nella directory corrente.

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

Se questo comando viene eseguito correttamente, riceverai alcune notifiche di successo insieme al seguente messaggio.

Database restored in 0.26 seconds

Questo capitolo spiega come connettersi a un database particolare dalla riga di comando di OrientDB. Apre un database.

La seguente dichiarazione è la sintassi di base del comando Connect.

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

Di seguito sono riportati i dettagli sulle opzioni nella sintassi precedente.

<database-url>- Definisce l'URL del database. L'URL contiene due parti: una è <mode> e la seconda è <path>.

<mode> - Definisce la modalità, ovvero modalità locale o modalità remota.

<path> - Definisce il percorso del database.

<user> - Definisce l'utente che si desidera connettere al database.

<password> - Definisce la password per la connessione al database.

Esempio

Abbiamo già creato un database denominato "demo" nei capitoli precedenti. In questo esempio, ci collegheremo a quello utilizzando l'utente admin.

È possibile utilizzare il seguente comando per connettersi al database demo.

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

Se è collegato correttamente, otterrai il seguente output:

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

Questo capitolo spiega come disconnettersi da un database particolare dalla riga di comando di OrientDB. Chiude il database attualmente aperto.

La seguente dichiarazione è la sintassi di base del comando Disconnect.

DISCONNECT

Note - È possibile utilizzare questo comando solo dopo essersi connessi a un determinato database e chiuderà solo il database attualmente in esecuzione.

Esempio

In questo esempio, useremo lo stesso database denominato "demo" che abbiamo creato nel capitolo precedente. Ci disconnetteremo dal database demo.

È possibile utilizzare il seguente comando per disconnettere il database.

orientdb {db = demo}> DISCONNECT

Se viene disconnesso correttamente, otterrai il seguente output:

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

Questo capitolo spiega come ottenere informazioni su un database particolare dalla riga di comando di OrientDB.

La seguente dichiarazione è la sintassi di base del comando Info.

info

Note - È possibile utilizzare questo comando solo dopo essersi connessi a un determinato database e recupererà le informazioni solo del database attualmente in esecuzione.

Esempio

In questo esempio, useremo lo stesso database denominato "demo" che abbiamo creato nel capitolo precedente. Recupereremo le informazioni di base dal database demo.

È possibile utilizzare il seguente comando per disconnettere il database.

orientdb {db = demo}> info

Se viene disconnesso correttamente, otterrai il seguente output.

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

Questo capitolo spiega come ottenere l'elenco di tutti i database in un'istanza dalla riga di comando di OrientDB.

La seguente dichiarazione è la sintassi di base del comando info.

LIST DATABASES

Note - È possibile utilizzare questo comando solo dopo essersi connessi a un server locale o remoto.

Esempio

Prima di recuperare l'elenco dei database, dobbiamo connetterci al server localhost tramite il server remoto. È necessario ricordare che il nome utente e la password per la connessione all'istanza localhost sono rispettivamente guest e guest, configurati nelorintdb/config/orientdb-server-config.xml file.

È possibile utilizzare il seguente comando per connettersi all'istanza del server di database localhost.

orientdb> connect remote:localhost guest

Chiederà la password. Come per il file di configurazione, anche la password del guest è guest. Se è collegato correttamente, otterrai il seguente output.

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

Dopo essersi connessi al server del database localhost è possibile utilizzare il seguente comando per elencare i database.

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

Se viene eseguito con successo, otterrai il seguente output:

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

Ogni volta che si desidera rendere statico lo stato del database, si intende uno stato in cui il database non ha risposto a nessuna delle operazioni di lettura e scrittura. Detto semplicemente, il database è in stato di blocco.

In questo capitolo, puoi imparare come congelare il database dalla riga di comando di OrientDB.

La seguente dichiarazione è la sintassi di base del comando freeze database.

FREEZE DATABASE

Note - È possibile utilizzare questo comando solo dopo essersi connessi a un determinato database nel database remoto o locale.

Esempio

In questo esempio, useremo lo stesso database denominato "demo" che abbiamo creato nel capitolo precedente. Congeleremo questo database dalla CLI.

È possibile utilizzare il seguente comando per bloccare il database.

Orientdb {db = demo}> FREEZE DATABASE

Se viene eseguito con successo, otterrai il seguente output.

Database 'demo' was frozen successfully

In questo capitolo è possibile apprendere come rilasciare il database dallo stato di blocco tramite la riga di comando di OrientDB.

La seguente dichiarazione è la sintassi di base del comando Release database.

RELEASE DATABASE

Note - È possibile utilizzare questo comando solo dopo essersi connessi a un particolare database, che è in stato di blocco.

Esempio

In questo esempio, useremo lo stesso database denominato "demo" che abbiamo creato nel capitolo precedente. Rilasceremo il database che è stato congelato nel capitolo precedente.

È possibile utilizzare il seguente comando per rilasciare il database.

Orientdb {db = demo}> RELEASE DATABASE

Se viene eseguito con successo, otterrai il seguente output.

Database 'demo' was release successfully

In questo capitolo è possibile apprendere come visualizzare la configurazione di un database particolare tramite la riga di comando di OrientDB. Questo comando è applicabile sia ai database locali che a quelli remoti.

Le informazioni di configurazione contengono la cache predefinita abilitata o meno, la dimensione della cache, il valore del fattore di carico, la memoria massima per la mappa, la dimensione della pagina del nodo, la dimensione minima e massima del pool, ecc.

La seguente istruzione è la sintassi di base del comando del database di configurazione.

CONFIG

Note - È possibile utilizzare questo comando solo dopo essersi connessi a un determinato database.

Esempio

In questo esempio, useremo lo stesso database denominato "demo" che abbiamo creato nel capitolo precedente.

È possibile utilizzare il seguente comando per visualizzare la configurazione del database demo.

Orientdb {db = demo}> CONFIG

Se viene eseguito con successo, otterrai il seguente output.

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

Nell'elenco precedente dei parametri di configurazione, se si desidera modificare uno qualsiasi del valore del parametro, è possibile farlo facilmente dalla riga di comando utilizzando config set e get command.

Set di configurazione

È possibile aggiornare il valore della variabile di configurazione utilizzando il CONFIG SET comando.

La seguente dichiarazione è la sintassi di base del comando config set.

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

Note - È possibile utilizzare questo comando solo dopo essersi connessi a un determinato database.

Esempio

In questo esempio, useremo lo stesso database denominato "demo" che abbiamo creato nel capitolo precedente. Modificheremo il valore della variabile "tx.autoRetry" su 5.

È possibile utilizzare il seguente comando per impostare la configurazione del database demo.

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

Se viene eseguito con successo, otterrai il seguente output.

Local configuration value changed correctly

Config Get

È possibile visualizzare il valore della variabile di configurazione utilizzando il CONFIG GET comando.

La seguente dichiarazione è la sintassi di base del comando config get.

CONFIG GET <config-variable>

Note - È possibile utilizzare questo comando solo dopo essersi connessi a un determinato database.

Esempio

In questo esempio, useremo lo stesso database denominato "demo" che abbiamo creato nel capitolo precedente. Cercheremo di recuperare il valore della variabile "tx.autoRetry".

È possibile utilizzare il seguente comando per visualizzare la configurazione del database demo.

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

Se viene eseguito con successo, otterrai il seguente output.

Local configuration: tx.autoRetry = 5

Come RDBMS, OrientDB fornisce anche funzionalità come Esporta e Importa il database. OrientDB utilizza il formato JSON per esportare i dati. Per impostazione predefinita, il comando di esportazione utilizza l'algoritmo GZIP per comprimere i file.

Durante l'esportazione un database non blocca il database, il che significa che è possibile eseguire operazioni di lettura e scrittura simultanee su di esso. Significa anche che è possibile creare una copia esatta di quei dati a causa di operazioni di lettura e scrittura simultanee.

In questo capitolo, puoi imparare come esportare il database dalla riga di comando di OrientDB.

La seguente dichiarazione è la sintassi di base del comando Esporta database.

EXPORT DATABASE <output file>

Note - È possibile utilizzare questo comando solo dopo essersi connessi a un determinato database.

Esempio

In questo esempio, useremo lo stesso database denominato "demo" che abbiamo creato nel capitolo precedente. È possibile utilizzare il seguente comando per esportare il database in un file denominato "export-demo".

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

Se viene eseguito con successo, creerà un file denominato "export-demo.zip" o "exportdemo.gz" in base al sistema operativo e otterrai il seguente output.

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

Ogni volta che si desidera importare il database, è necessario utilizzare il file esportato in formato JSON, generato dal comando di esportazione.

In questo capitolo puoi imparare come importare il database dalla riga di comando di OrientDB.

La seguente dichiarazione è la sintassi di base del comando Importa database.

IMPORT DATABASE <input file>

Note - È possibile utilizzare questo comando solo dopo essersi connessi a un determinato database.

Esempio

In questo esempio, useremo lo stesso database denominato "demo" che abbiamo creato nel capitolo precedente. È possibile utilizzare il seguente comando per importare il database in un file denominato "export-demo.gz".

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

Se viene eseguito correttamente, riceverai il seguente output insieme alla notifica di successo.

Database import completed in 11612ms

Simile a RDBMS, OrientDB fornisce anche concetti di transazione come Commit e Rollback. Commit si riferisce alla chiusura della transazione salvando tutte le modifiche nel database. Rollback si riferisce al ripristino dello stato del database fino al punto in cui è stata aperta la transazione.

La seguente istruzione è la sintassi di base del comando del database Commit.

COMMIT

Note - È possibile utilizzare questo comando solo dopo essersi connessi a un determinato database e dopo aver iniziato la transazione.

Esempio

In questo esempio, useremo lo stesso database denominato "demo" che abbiamo creato nel capitolo precedente. Vedremo l'operazione di commit della transazione e memorizzeremo un record usando le transazioni.

Innanzitutto, avvia la transazione utilizzando quanto segue BEGIN comando.

orientdb {db = demo}> BEGIN

Quindi, inserisci un record in una tabella dei dipendenti con i valori id = 12 e name = satish.P utilizzando il seguente comando.

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

È possibile utilizzare il seguente comando per eseguire il commit della transazione.

orientdb> commit

Se il commit di questa transazione viene eseguito correttamente, otterrai il seguente output.

Transaction 2 has been committed in 4ms

In questo capitolo imparerai come ripristinare la transazione non impegnata tramite l'interfaccia della riga di comando di OrientDB.

La seguente istruzione è la sintassi di base del comando di database Rollback.

ROLLBACK

Note - È possibile utilizzare questo comando solo dopo essersi connessi a un determinato database e dopo aver iniziato la transazione.

Esempio

In questo esempio, useremo lo stesso database denominato "demo" che abbiamo creato nel capitolo precedente. Vedremo l'operazione di rollback della transazione e memorizzeremo un record utilizzando le transazioni.

Innanzitutto, avvia la transazione utilizzando quanto segue BEGIN comando.

orientdb {db = demo}> BEGIN

Quindi, inserisci un record in una tabella dei dipendenti con i valori id = 12 e name = satish.P utilizzando il seguente comando.

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

È possibile utilizzare il seguente comando per recuperare i record dalla tabella Employee.

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

Se questo comando viene eseguito correttamente, otterrai il seguente output.

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

È ora possibile utilizzare il seguente comando per eseguire il rollback di questa transazione.

orientdb> ROLLBACK

Controllare di nuovo la query di selezione per recuperare lo stesso record dalla tabella dei dipendenti.

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

Se il rollback viene eseguito correttamente, otterrai 0 record trovati nell'output.

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

Secondo la terminologia tecnica Optimizationsignifica "Ottieni le migliori prestazioni possibili nel più breve tempo possibile". Con riferimento al database, l'ottimizzazione implica la massimizzazione della velocità e dell'efficienza con cui i dati vengono recuperati.

OrientDB supporta bordi leggeri, il che significa una relazione diretta tra le entità di dati. In termini semplici, è una relazione da campo a campo. OrientDB fornisce diversi modi per ottimizzare il database. Supporta la conversione di bordi regolari in bordi leggeri.

La seguente dichiarazione è la sintassi di base del comando di database Optimize.

OPTMIZE DATABASE [-lwedges] [-noverbose]

Dove lwedges converte i bordi regolari in bordi leggeri e noverbose disabilita l'uscita.

Esempio

In questo esempio, useremo lo stesso database denominato "demo" che abbiamo creato nel capitolo precedente. È possibile utilizzare il seguente comando di ottimizzazione del database.

OPTIMIZE DATABASE -lwedges

Se viene eseguito correttamente, riceverai alcune notifiche di successo insieme al messaggio di completamento.

Database Optimization completed in 35ms

Simile a RDBMS, OrientDB fornisce la funzionalità per eliminare un database. Drop database si riferisce alla rimozione completa di un database.

La seguente dichiarazione è la sintassi di base del comando Elimina database.

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

Di seguito sono riportati i dettagli sulle opzioni nella sintassi precedente.

<database-name> - Nome del database che desideri eliminare.

<server-username> - Nome utente del database che ha il privilegio di eliminare un database.

<server-user-password> - Password dell'utente specifico.

Esempio

Esistono due modi per eliminare un database, uno è eliminare un database attualmente aperto e il secondo è eliminare un database particolare fornendo il nome specifico.

In questo esempio, useremo lo stesso database denominato "demo" che abbiamo creato in un capitolo precedente. È possibile utilizzare il seguente comando per eliminare un databasedemo.

orientdb {db = demo}> DROP DATABASE

Se questo comando viene eseguito con successo, otterrai il seguente output.

Database 'demo' deleted successfully

OR

È possibile utilizzare un altro comando per eliminare un database come segue.

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

Se questo comando viene eseguito con successo, otterrai il seguente output.

Database 'demo' deleted successfully

OrientDB è un database NoSQL in grado di archiviare documenti e dati orientati ai grafici. Il database NoSQL non contiene alcuna tabella, quindi come puoi inserire i dati come record. Qui puoi vedere i dati della tabella sotto forma di classe, proprietà, vertice e bordo che significa che le classi sono come le tabelle e le proprietà sono come i file nelle tabelle.

Possiamo definire tutte queste entità usando schemain OrientDB. I dati delle proprietà possono essere inseriti in una classe. Il comando Inserisci crea un nuovo record nello schema del database. I record possono essere privi di schema o seguire alcune regole specificate.

La seguente dichiarazione è la sintassi di base del comando Inserisci record.

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

Di seguito sono riportati i dettagli sulle opzioni nella sintassi precedente.

SET - Definisce ogni campo insieme al valore.

CONTENT- Definisce i dati JSON per impostare i valori dei campi. Questo è opzionale.

RETURN- Definisce l'espressione da restituire invece del numero di record inseriti. I casi d'uso più comuni sono:

  • @rid - Restituisce l'ID record del nuovo record.

  • @this - Restituisce l'intero nuovo record.

FROM - Dove vuoi inserire il record o un set di risultati.

Esempio

Consideriamo una tabella Cliente con i seguenti campi e tipi.

Sr.No. Nome campo genere
1 Id Numero intero
2 Nome Corda
3 Età Numero intero

È possibile creare lo schema (tabella) eseguendo i seguenti comandi.

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

Dopo aver eseguito tutti i comandi, otterrai il nome della tabella Customer con i campi id, name ed age. È possibile controllare la tabella eseguendo la query di selezione nella tabella Customer.

OrientDB offre diversi modi per inserire un record. Considera la seguente tabella Customer contenente i record di esempio.

Sr.No. Nome Età
1 Satish 25
2 Krishna 26
3 Kiran 29
4 Javeed 21
5 Raja 29

Il comando seguente consiste nell'inserire il primo record nella tabella Customer.

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

Se il comando precedente viene eseguito con successo, otterrai il seguente output.

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

Il comando seguente consiste nell'inserire il secondo record nella tabella Customer.

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

Se il comando precedente viene eseguito con successo, otterrai il seguente output.

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

Il comando seguente consiste nell'inserire il terzo record nella tabella Customer.

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

Se il comando precedente viene eseguito con successo, otterrai il seguente output.

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

Il comando seguente consiste nell'inserire i due record successivi nella tabella Customer.

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

Se il comando precedente viene eseguito con successo, otterrai il seguente output.

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).

Puoi verificare se tutti questi record sono inseriti o meno eseguendo il seguente comando.

SELECT FROM Customer

Se il comando precedente viene eseguito con successo, otterrai il seguente output.

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

Simile a RDBMS, OrientDB supporta diversi tipi di query SQL per recuperare i record dal database. Durante il recupero dei record abbiamo diverse varianti o opzioni di query insieme all'istruzione select.

La seguente dichiarazione è la sintassi di base del comando 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 ]

Di seguito sono riportati i dettagli sulle opzioni nella sintassi precedente.

<Projections> - Indica i dati che si desidera estrarre dalla query come set di record dei risultati.

FROM- Indica l'oggetto da interrogare. Può essere una classe, un cluster, un singolo ID record, un set di ID record. È possibile specificare tutti questi oggetti come destinazione.

WHERE - Specifica la condizione per filtrare il set di risultati.

LET - Indica la variabile di contesto utilizzata nelle proiezioni, condizioni o sottoquery.

GROUP BY - Indica il campo per raggruppare i record.

ORDER BY - Indica l'archivio per organizzare un record in ordine.

UNWIND - Designa il campo su cui svolgere la raccolta di record.

SKIP - Definisce il numero di record che si desidera saltare dall'inizio del set di risultati.

LIMIT - Indica il numero massimo di record nel set di risultati.

FETCHPLAN - Specifica la strategia che definisce come si desidera recuperare i risultati.

TIMEOUT - Definisce il tempo massimo in millisecondi per la query.

LOCK- Definisce la strategia di chiusura. DEFAULT e RECORD sono le strategie di blocco disponibili.

PARALLEL - Esegue la query su thread simultanei "x".

NOCACHE - Definisce se si desidera utilizzare la cache o meno.

Esempio

Consideriamo la seguente tabella Customer creata nel capitolo precedente.

Sr.No. Nome Età
1 Satish 25
2 Krishna 26
3 Kiran 29
4 Javeed 21
5 Raja 29

Prova diverse query di selezione per recuperare i record di dati dalla tabella Cliente.

Method 1 - È possibile utilizzare la seguente query per selezionare tutti i record dalla tabella Clienti.

orientdb {db = demo}> SELECT FROM Customer

Se la query precedente viene eseguita correttamente, otterrai il seguente output.

----+-----+--------+----+-------+---- 
#   |@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 - Seleziona tutti i record il cui nome inizia con la lettera 'k'.

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

OPPURE puoi utilizzare la seguente query per l'esempio precedente.

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

Se la query precedente viene eseguita correttamente, otterrai il seguente output.

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

Method 3 - Seleziona id, record di nome dalla tabella Customer con i nomi in lettere maiuscole.

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

Se la query precedente viene eseguita correttamente, otterrai il seguente output.

----+--------+----+------- 
#   |@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 - Seleziona tutti i record dalla tabella Cliente in cui l'età è compresa tra 25 e 29 anni.

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

Se la query precedente viene eseguita correttamente, otterrai il seguente output.

----+-----+--------+----+-------+---- 
#   |@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 - Seleziona tutti i record dalla tabella Cliente in cui qualsiasi campo contiene la parola "sh".

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

Se la query precedente viene eseguita correttamente, otterrai il seguente output.

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

Method 6 - Seleziona tutti i record dalla tabella Cliente, ordinati per età in ordine decrescente.

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

Se la query precedente viene eseguita correttamente, otterrai il seguente output.

----+-----+--------+----+-------+---- 
#   |@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 Recordviene utilizzato per caricare un particolare record dallo schema. Carica record caricherà il record con l'aiuto di ID record. È rappresentato con@rid simbolo nel gruppo di risultati.

La seguente dichiarazione è la sintassi di base del comando LOAD Record.

LOAD RECORD <record-id>

Dove <record-id> definisce l'ID record del record che desideri caricare.

Se non conosci l'ID record di un record particolare, puoi eseguire qualsiasi query sulla tabella. Nel set di risultati troverai l'ID record (@rid) del rispettivo record.

Esempio

Consideriamo la stessa tabella Customer che abbiamo utilizzato nei capitoli precedenti.

Sr.No. Nome Età
1 Satish 25
2 Krishna 26
3 Kiran 29
4 Javeed 21
5 Raja 29

Prova la seguente query per recuperare il record con ID record @rid: #11:0.

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

Se la query precedente viene eseguita correttamente, otterrai il seguente output.

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

Reload Recordfunziona anche in modo simile al comando Carica record e viene utilizzato anche per caricare un particolare record dallo schema. Carica record caricherà il record con l'aiuto di ID record. È rappresentato con@ridsimbolo nel set di risultati. La differenza principale è che Ricarica record ignora la cache, il che è utile quando vengono applicate transazioni simultanee esterne per modificare il record. Fornirà l'ultimo aggiornamento.

La seguente dichiarazione è la sintassi di base del comando RELOAD Record.

RELOAD RECORD <record-id>

Dove <record-id> definisce l'ID record del record che desideri ricaricare.

Se non conosci l'ID record di un record particolare, puoi eseguire qualsiasi query sulla tabella. Nel set di risultati troverai l'ID record (@rid) del rispettivo record.

Esempio

Consideriamo la stessa tabella Customer che abbiamo utilizzato nel capitolo precedente.

Sr.No. Nome Età
1 Satish 25
2 Krishna 26
3 Kiran 29
4 Javeed 21
5 Raja 29

Prova la seguente query per recuperare il record con ID record @rid: #11:0.

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

Se la query precedente viene eseguita correttamente, otterrai il seguente output.

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

Export Recordè il comando utilizzato per esportare il record caricato nel formato richiesto e supportato. Se stai eseguendo una sintassi sbagliata, ti verrà fornito l'elenco dei formati supportati. OrientDB è una famiglia di database di documenti, quindi JSON è il formato supportato predefinito.

La seguente dichiarazione è la sintassi di base del comando Esporta record.

EXPORT RECORD <format>

Dove <Format> definisce il formato in cui desideri ottenere il record.

Note - Il comando Esporta esporterà il record caricato in base all'ID record.

Esempio

Consideriamo la stessa tabella Customer che abbiamo utilizzato nel capitolo precedente.

Sr.No. Nome Età
1 Satish 25
2 Krishna 26
3 Kiran 29
4 Javeed 21
5 Raja 29

Prova la seguente query per recuperare il record con ID record @rid: #11:0.

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

Se la query precedente viene eseguita correttamente, otterrai il seguente output.

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

Utilizza la seguente query per esportare il record caricato (# 11: 0) in formato JSON.

orientdb {db = demo}> EXPORT RECORD json

Se la query precedente viene eseguita correttamente, otterrai il seguente output.

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

Update Recordcomando viene utilizzato per modificare il valore di un particolare record. SET è il comando di base per aggiornare un particolare valore di campo.

La seguente dichiarazione è la sintassi di base del comando Update.

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

Di seguito sono riportati i dettagli sulle opzioni nella sintassi precedente.

SET - Definisce il campo da aggiornare.

INCREMENT - Incrementa il valore del campo specificato del valore specificato.

ADD - Aggiunge il nuovo elemento nei campi di raccolta.

REMOVE - Rimuove un elemento dal campo di raccolta.

PUT - Inserisce una voce nel campo della mappa.

CONTENT - Sostituisce il contenuto del record con il contenuto del documento JSON.

MERGE - Unisce il contenuto del record con un documento JSON.

LOCK- Specifica come bloccare i record tra il caricamento e l'aggiornamento. Abbiamo due opzioni da specificareDefault e Record.

UPSERT- Aggiorna un record se esiste o inserisce un nuovo record in caso contrario. Aiuta nell'esecuzione di una singola query al posto dell'esecuzione di due query.

RETURN - Specifica un'espressione da restituire invece del numero di record.

LIMIT - Definisce il numero massimo di record da aggiornare.

TIMEOUT - Definisce il tempo in cui si desidera consentire l'esecuzione dell'aggiornamento prima che scada.

Esempio

Consideriamo la stessa tabella Customer che abbiamo utilizzato nel capitolo precedente.

Sr.No. Nome Età
1 Satish 25
2 Krishna 26
3 Kiran 29
4 Javeed 21
5 Raja 29

Prova la seguente query per aggiornare l'età di un cliente "Raja".

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

Se la query precedente viene eseguita correttamente, otterrai il seguente output.

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

Per controllare il record della tabella clienti è possibile utilizzare la seguente query.

orientdb {db = demo}> SELECT FROM Customer

Se la query precedente viene eseguita correttamente, otterrai il seguente output.

----+-----+--------+----+-------+---- 
#   |@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 comando viene utilizzato per eliminare i valori di un particolare record.

La seguente istruzione è la sintassi di base del comando Truncate.

TRUNCATE RECORD <rid>*

Dove <rid>* indica l'ID record da troncare. È possibile utilizzare più RID separati da virgola per troncare più record. Restituisce il numero di record troncati.

Esempio

Consideriamo la stessa tabella Customer che abbiamo utilizzato nel capitolo precedente.

Sr.No. Nome Età
1 Satish 25
2 Krishna 26
3 Kiran 29
4 Javeed 21
5 Raja 28

Prova la seguente query per troncare il record con ID record # 11: 4.

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

Se la query precedente viene eseguita correttamente, otterrai il seguente output.

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

Per controllare il record della tabella clienti è possibile utilizzare la seguente query.

Orientdb {db = demo}> SELECT FROM Customer

Se la query precedente viene eseguita correttamente, otterrai il seguente output.

----+-----+--------+----+-------+---- 
#   |@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 viene utilizzato per eliminare completamente uno o più record dal database.

La seguente dichiarazione è la sintassi di base del comando Elimina.

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

Di seguito sono riportati i dettagli sulle opzioni nella sintassi precedente.

LOCK- Specifica come bloccare i record tra il caricamento e l'aggiornamento. Abbiamo due opzioni da specificareDefault e Record.

RETURN - Specifica un'espressione da restituire invece del numero di record.

LIMIT - Definisce il numero massimo di record da aggiornare.

TIMEOUT - Definisce il tempo in cui si desidera consentire l'esecuzione dell'aggiornamento prima che scada.

Note - Non utilizzare DELETE per rimuovere vertici o bordi perché influisce sull'integrità del grafico.

Esempio

Consideriamo la tabella dei clienti.

Sr.No. Nome Età
1 Satish 25
2 Krishna 26
3 Kiran 29
4 Javeed 21

Prova la seguente query per eliminare il record con id = 4.

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

Se la query precedente viene eseguita correttamente, otterrai il seguente output.

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

Per controllare il record della tabella clienti è possibile utilizzare la seguente query.

Orientdb {db = demo}> SELECT FROM Customer

Se la query precedente viene eseguita correttamente, otterrai il seguente output.

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

OrientDB supporta la funzionalità multi-modello e fornisce diversi modi per avvicinarsi e comprendere i concetti di base di un database. Tuttavia, possiamo accedere facilmente a questi modelli dalla prospettiva dell'API del database dei documenti. Come RDBMS, anche OrientDB utilizza il record come elemento di archiviazione ma utilizza il tipo di documento. I documenti vengono archiviati sotto forma di coppie chiave / valore. Stiamo memorizzando campi e proprietà come coppie chiave / valore che appartengono a una classe di concetti.

Classè un tipo di modello di dati e il concetto è tratto dal paradigma di programmazione orientata agli oggetti. In base al modello di database dei documenti tradizionale, i dati vengono archiviati sotto forma di raccolta, mentre nel modello di database relazionale i dati vengono archiviati in tabelle. OrientDB segue l'API del documento insieme al paradigma OPPS. Come concetto, la classe in OrientDB ha la relazione più stretta con la tabella nei database relazionali, ma (a differenza delle tabelle) le classi possono essere senza schema, complete di schema o miste. Le classi possono ereditare da altre classi, creando alberi di classi. Ogni classe ha il proprio cluster o cluster, (creati per impostazione predefinita, se nessuno è definito).

La seguente dichiarazione è la sintassi di base del comando Create Class.

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

Di seguito sono riportati i dettagli sulle opzioni nella sintassi precedente.

<class> - Definisce il nome della classe che desideri creare.

<super-class> - Definisce la superclasse che desideri estendere con questa classe.

<total-cluster-number>- Definisce il numero totale di cluster utilizzati in questa classe. L'impostazione predefinita è 1.

ABSTARCT- Definisce che la classe è astratta. Questo è opzionale.

Esempio

Come discusso, la classe è un concetto correlato alla tabella. Quindi qui creeremo una tabella Account. Tuttavia, durante la creazione della classe non possiamo definire campi, cioè proprietà basate sul paradigma OOPS.

Il comando seguente serve per creare una classe denominata Account.

orientdb> CREATE CLASS Account

Se il comando precedente viene eseguito correttamente, otterrai il seguente output.

Class created successfully

È possibile utilizzare il seguente comando per creare una classe Car che si estende alla classe Vehicle.

orientdb> CREATE CLASS Car EXTENDS Vehicle

Se il comando precedente viene eseguito correttamente, otterrai il seguente output.

Class created successfully

È possibile utilizzare il seguente comando per creare una classe Person come abstract.

orientdb> CREATE CLASS Person ABSTRACT

Se il comando precedente viene eseguito correttamente, otterrai il seguente output.

Class created successfully

Note- Senza avere proprietà, la classe è inutile e incapace di costruire oggetti reali. Nei capitoli successivi, puoi imparare come creare proprietà per una particolare classe.

Classe e proprietà in OrientDB vengono utilizzate per creare uno schema con i rispettivi attributi come nome classe, superclasse, cluster, numero di cluster, Abstract, ecc. Se si desidera modificare o aggiornare qualsiasi attributo delle classi esistenti nello schema, allora devi usare Alter Class comando.

La seguente dichiarazione è la sintassi di base del comando Alter Class.

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

Di seguito sono riportati i dettagli sulle opzioni nella sintassi precedente.

<class> - Definisce il nome della classe.

<attribute-name> - Definisce l'attributo che desideri modificare.

<attribute-value> - Definisce il valore che si desidera impostare per l'attributo.

La tabella seguente definisce l'elenco degli attributi che supportano il comando Alter Class.

Attributo genere Descrizione
NOME Corda Modifica il nome della classe.
NOME CORTO Corda Definisce un nome breve (ovvero un alias) per la classe. Utilizzare NULL per rimuovere un'assegnazione di un nome breve.
SUPERCLASS Corda Definisce una superclasse per la classe. Per aggiungere una nuova classe, puoi usare la sintassi + <class>, per rimuoverla usa - <class>.
OVERSIZE Numero decimale Definisce il fattore di sovradimensionamento.
ADDCLUSTER Corda Aggiunge un cluster alla classe. Se il cluster non esiste, crea un cluster fisico. L'aggiunta di cluster a una classe è utile anche per archiviare record in server distribuiti.
REMOVECLUSTER Corda Rimuove un cluster da una classe. Non elimina il cluster, lo rimuove solo dalla classe.
STRICTMODE - Abilita o disabilita la modalità rigorosa. In modalità rigorosa, si lavora in modalità schema completo e non è possibile aggiungere nuove proprietà a un record se fanno parte della definizione dello schema della classe.
SELEZIONE DEL CLUSTER - Definisce la strategia di selezione nella scelta del cluster da utilizzare per i nuovi record.
PERSONALIZZATO - Definisce le proprietà personalizzate. I nomi e i valori delle proprietà devono seguire la sintassi <propertyname> = <value> senza spazi tra il nome e il valore.
ASTRATTO Booleano Converte la classe in una classe astratta o viceversa.

Esempio

Proviamo alcuni esempi che aggiorneranno o modificheranno gli attributi della classe esistente.

La seguente query viene utilizzata per definire una superclasse "Persona" per una classe esistente "Impiegato".

orientdb> ALTER CLASS Employee SUPERCLASS Person

Se la query precedente viene eseguita correttamente, otterrai il seguente output.

Class altered successfully

La seguente query viene utilizzata per aggiungere una "Persona" di superclasse per una classe esistente "Dipendente".

orientdb> ALTER CLASS Employee SUPERCLASS +Person

Se la query precedente viene eseguita correttamente, otterrai il seguente output.

Class altered successfully

Truncate classcancellerà tutti i record dei cluster definiti come parte della classe. In OrientDB, ogni classe ha un cluster associato con lo stesso nome. Se si desidera rimuovere anche tutti i record dalla gerarchia di classi, è necessario utilizzare la parola chiave POLYMORPHIC.

La seguente dichiarazione è la sintassi di base di Truncate Class Command.

TRUNCATE CLASS <class> [ POLYMORPHIC ] [ UNSAFE ]

Di seguito sono riportati i dettagli sulle opzioni nella sintassi precedente.

<class> - Definisce la classe che si desidera troncare.

POLYMORPHIC - Definisce se il comando tronca anche la gerarchia.

UNSAFE - Definisce il comando forza il troncamento sulla classe del vertice o del bordo.

Esempio

La seguente query per troncare una classe Profile.

orientdb> TRUNCATE CLASS Profile

Se la query precedente viene eseguita correttamente, otterrai il seguente output.

Class truncated successfully

Il Drop ClassIl comando rimuove una classe dallo schema. È importante prestare attenzione e mantenere uno schema coerente. Ad esempio, evitare di rimuovere le classi che sono superclassi di altre. Il cluster associato non verrà eliminato.

La seguente dichiarazione è la sintassi di base del comando Drop Class.

DROP CLASS <class>

Rilascia una classe con il nome della classe.

Esempio

Prova la seguente query per eliminare un dipendente di classe.

Orientdb> DROP CLASS Employee

Se la query precedente viene eseguita correttamente, otterrai il seguente output.

Class dropped successfully

Clusterè un concetto importante in OrientDB che viene utilizzato per memorizzare record, documenti o vertici. In parole semplici, il cluster è un luogo in cui viene archiviato un gruppo di record. Per impostazione predefinita, OrientDB creerà un cluster per classe. Tutti i record di una classe vengono archiviati nello stesso cluster, che ha lo stesso nome della classe. È possibile creare fino a 32.767 (2 ^ 15-1) cluster in un database.

La classe CREATE è un comando utilizzato per creare un cluster con un nome specifico. Una volta creato il cluster, è possibile utilizzare il cluster per salvare i record specificando il nome durante la creazione di qualsiasi modello di dati. Se desideri aggiungere un nuovo cluster a una classe, utilizza il comando Alter Class e il comando ADDCLUSTER.

La seguente dichiarazione è la sintassi di base del comando Crea cluster.

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

Dove <cluster> definisce il nome del cluster che si desidera creare e <cluster-id> definisce l'ID numerico che si desidera utilizzare per il cluster.

La tabella seguente fornisce l'elenco delle strategie di selezione del cluster.

Sr.No. Strategia e descrizione
1

Default

Seleziona il cluster utilizzando la proprietà della classe ClusterId predefinita.

2

Round-robin

Seleziona il cluster successivo in ordine circolare. Si riavvia una volta completato.

3

Balanced

Seleziona il cluster più piccolo. Consente alla classe di avere tutti i cluster sottostanti bilanciati in base alle dimensioni. Quando si aggiunge un nuovo cluster a una classe esistente, riempie prima il nuovo cluster.

Esempio

Facciamo un esempio per creare un cluster denominato sales.

orientdb> CREATE CLUSTER sales

Se la query precedente viene eseguita correttamente, otterrai il seguente output.

Cluster created correctly with id #12

Alter Clusteril comando è aggiornare gli attributi su un cluster esistente. In questo capitolo è possibile apprendere come aggiungere o modificare gli attributi di un cluster.

La seguente dichiarazione è la sintassi di base del comando Alter Cluster.

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

Di seguito sono riportati i dettagli sulle opzioni nella sintassi precedente.

<cluster> - Definisce il nome del cluster.

<attribute-name> - Definisce l'attributo che desideri modificare.

<attribute-value> - Definisce il valore che si desidera impostare per questo attributo.

Il seguente formato tabulare fornisce l'elenco degli attributi supportati che è possibile utilizzare insieme al comando Alter cluster.

Nome genere Descrizione
NOME Corda Modifica il nome del cluster.
STATO Corda Modifica lo stato del cluster. I valori consentiti sono ONLINE e OFFLINE. Per impostazione predefinita, i cluster sono online.
COMPRESSIONE Corda Definisce il tipo di compressione da utilizzare. I valori consentiti sono NOTHING, SNAPPY, GZIP e qualsiasi altro tipo di compressione registrato nella classe OCompressionFactory.
USE_WAL Booleano Definisce se utilizza il Journal quando OrientDB opera sul cluster
RECORD_GROW_FACTO R Numero intero Definisce il fattore di crescita per risparmiare più spazio sulla creazione del record. Può essere utile quando aggiorni il record con informazioni aggiuntive.
RECORD_OVERFLOW_GR OW_FACTOR Numero intero Definisce il fattore di crescita sugli aggiornamenti. Quando raggiunge il limite di dimensione, utilizza questa impostazione per ottenere più spazio, (fattore> 1).
STRATEGIA DI CONFLITTO Corda Definisce la strategia che utilizza per gestire i conflitti nel caso in cui OrientDB MVCC trovi un aggiornamento o un'operazione di eliminazione eseguita su un vecchio record.

La tabella seguente fornisce l'elenco delle strategie di conflitto.

Sr.No. Strategia e descrizione
1

Version

Genera un'eccezione quando le versioni sono diverse. Questa è l'impostazione predefinita.

2

Content

Nel caso in cui le versioni siano diverse, verifica le modifiche nel contenuto, altrimenti utilizza la versione più alta per evitare di generare un'eccezione.

3

Automerge

Unisce le modifiche.

Esempio

Prova le seguenti query di esempio per apprendere il comando Alter cluster.

Eseguire il comando seguente per modificare il nome di un cluster da Employee a Employee2.

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

Se il comando precedente viene eseguito correttamente, otterrai il seguente output.

Cluster updated successfully

Eseguire il comando seguente per modificare il nome di un cluster da Employee2 a Employee utilizzando l'ID cluster.

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

Se il comando precedente viene eseguito correttamente, otterrai il seguente output.

Cluster updated successfully

Eseguire il comando seguente per modificare la strategia di conflitto del cluster in automerge.

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

Se il comando precedente viene eseguito correttamente, otterrai il seguente output.

Cluster updated successfully

Il Truncate Cluster Il comando elimina tutti i record di un cluster.

La seguente istruzione è la sintassi di base del comando Truncate Cluster.

TRUNCATE CLUSTER <cluster-name>

Dove <cluster-name> è il nome del cluster.

Esempio

Prova la seguente query per troncare il cluster denominato sales.

Orientdb {db = demo}> TRUNCATE CLUSTER Profile

Se la query precedente viene eseguita correttamente, otterrai il seguente output.

Cluster truncated successfully.

Il Drop ClusterIl comando rimuove il cluster e tutto il suo contenuto correlato. Questa operazione è permanente e ripristina.

La seguente dichiarazione è la sintassi di base del comando Drop Cluster.

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

Dove <cluster-name> definisce il nome del cluster che si desidera rimuovere e <cluster-id> definisce l'ID del cluster che desideri rimuovere.

Esempio

Prova il seguente comando per rimuovere il cluster di vendita.

orientdb> DROP CLUSTER Sales

Se la query precedente viene eseguita correttamente, otterrai il seguente output.

Cluster dropped successfully

Propertyin OrientDB funziona come un campo di classe e colonna nella tabella del database. Crea proprietà è un comando utilizzato per creare una proprietà per una particolare classe. Il nome della classe che hai utilizzato nel comando deve esistere.

La seguente dichiarazione è la sintassi di base del comando Crea proprietà.

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

Di seguito sono riportati i dettagli sulle opzioni nella sintassi precedente.

<class-name> - Definisce la classe in cui si desidera creare la proprietà.

<property-name> - Definisce il nome logico della proprietà.

<property-type> - Definisce il tipo di proprietà che desideri creare.

<linked-type> - Definisce il tipo di contenitore, utilizzato nel tipo di proprietà del contenitore.

<linked-class> - Definisce la classe del contenitore, utilizzata nel tipo di proprietà del contenitore.

La tabella seguente fornisce il tipo di dati per la proprietà in modo che OrientDB conosca il tipo di dati da archiviare.

BOOLEANO NUMERO INTERO CORTO LUNGO
GALLEGGIANTE DATA CORDA INCORPORATO
LINK BYTE BINARIO DOPPIO

Oltre a questi ci sono molti altri tipi di proprietà che funzionano come contenitori.

EMBEDDEDLIST EMBEDDEDSET EMBEDDEDMAP
LINKLIST LINKSET LINKMAP

Esempio

Prova il seguente esempio per creare un nome di proprietà sulla classe Employee, di tipo String.

orientdb> CREATE PROPERTY Employee.name STRING

Se la query precedente viene eseguita correttamente, otterrai il seguente output.

Property created successfully with id = 1

Alter Propertyè un comando utilizzato per modificare o aggiornare la proprietà di una particolare classe. Alterare la proprietà significa modificare i campi di una tabella. In questo capitolo è possibile apprendere come aggiornare la proprietà.

La seguente dichiarazione è la sintassi di base di Alter Property Command.

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

Di seguito sono riportati i dettagli sulle opzioni nella sintassi precedente.

<class> - Definisce la classe a cui appartiene la proprietà.

<property> - Definisce la proprietà che desideri aggiornare.

<attribute-name> - Definisce l'attributo di una proprietà che desideri aggiornare.

<attribute-value> - Definisce il valore che si desidera impostare sull'attributo.

La tabella seguente definisce l'elenco degli attributi per modificare la proprietà.

Attributo genere Descrizione
LINKEDCLASS Corda Definisce il nome della classe collegata. Utilizzare NULL per rimuovere un valore esistente.
LINKEDTYPE Corda Definisce il tipo di collegamento. Utilizzare NULL per rimuovere un valore esistente.
MIN Numero intero Definisce il valore minimo come vincolo. Utilizzare NULL per rimuovere un vincolo esistente.
OBBLIGATORIO Booleano Definisce se la proprietà richiede un valore.
MAX Numero intero Definisce il valore massimo come vincolo. Utilizzare NULL per rimuovere un vincolo esistente.
NOME Corda Definisce il nome della proprietà.
NON NULLO Booleano Definisce se la proprietà può avere un valore NULL.
REGEX Corda Definisce un'espressione regolare come vincolo. Utilizzare NULL per rimuovere un vincolo esistente.
GENERE Corda Definisce un tipo di proprietà.
FASCICOLARE Corda Imposta la fascicolazione su una delle strategie di confronto definite. Per impostazione predefinita, è impostato sulla distinzione tra maiuscole e minuscole (cs). Puoi anche impostarlo su case-insensitive (ci).
SOLA LETTURA Booleano Definisce se il valore della proprietà è immutabile. Cioè, se è possibile cambiarlo dopo il primo incarico. Utilizzare con DEFAULT per avere valori immutabili alla creazione.
PERSONALIZZATO Corda Definisce le proprietà personalizzate. La sintassi per le proprietà personalizzate è <custom-name> = <custom-value>, come stereotype = icon.
PREDEFINITO   Definisce il valore o la funzione di default.

Note - se stai modificando NOME o TIPO, l'aggiornamento di questo comando richiederà del tempo a seconda della quantità di dati.

Esempio

Prova alcune domande fornite di seguito per comprendere la proprietà Alter.

Eseguire la seguente query per modificare il nome della proprietà da "age" a "born" nella classe Customer.

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

Se la query precedente viene eseguita correttamente, otterrai il seguente output.

Property altered successfully

Eseguire la seguente query per rendere "nome" la proprietà obbligatoria della classe "Cliente".

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

Se la query precedente viene eseguita correttamente, otterrai il seguente output.

Property altered successfully

Il Drop propertyIl comando rimuove la proprietà dallo schema. Non rimuove i valori delle proprietà dal record, cambia solo lo schema.

La seguente istruzione è la sintassi di base del comando Drop Property.

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

Di seguito sono riportati i dettagli sulle opzioni nella sintassi precedente.

<class> - Definisce la classe in cui esiste la proprietà.

<property> - Definisce la proprietà che desideri rimuovere.

[Force] - Nel caso in cui uno o più indici siano definiti sulla proprietà.

Esempio

Prova il seguente comando per rimuovere la proprietà "age" dalla classe "Customer".

orientdb> DROP PROPERTY Customer.age

Se il comando precedente viene eseguito correttamente, otterrai il seguente output.

Property dropped successfully

Il database OrientDB non è solo un database di documenti ma anche un database di grafici. Nuovi concetti come Vertex e Edge vengono utilizzati per memorizzare i dati sotto forma di grafico. Applica il polimorfismo ai vertici. La classe base per Vertex è V.

In questo capitolo puoi imparare come creare un vertice per memorizzare i dati del grafico.

La seguente dichiarazione è la sintassi di base del comando Crea vertice.

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

Di seguito sono riportati i dettagli sulle opzioni nella sintassi precedente.

<class> - Definisce la classe a cui appartiene il vertice.

<cluster> - Definisce il cluster in cui memorizza il vertice.

<field> - Definisce il campo che si desidera impostare.

<expression> - Definisce l'espresso da impostare per il campo.

Esempio

Prova il seguente esempio per capire come creare il vertice.

Esegui la seguente query per creare un vertice senza 'nome' e sulla classe base V.

orientdb> CREATE VERTEX

Se la query precedente viene eseguita correttamente, otterrai il seguente output.

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

Esegui la seguente query per creare una nuova classe vertice denominata v1, quindi crea vertice in quella classe.

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

Se la query precedente viene eseguita correttamente, otterrai il seguente output.

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

Esegui la seguente query per creare un nuovo vertice della classe denominato v1, definendo le sue proprietà come brand = 'Maruti' e name = 'Swift'.

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

Se la query precedente viene eseguita correttamente, otterrai il seguente output.

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

Il comando Move Vertex in OrientDB serve a spostare uno o più vertici dalla posizione corrente a una classe o un cluster diverso. Se stai applicando il comando di spostamento su un particolare vertice, aggiornerà tutti i bordi che sono collegati a questo vertice. Se si specifica un cluster per spostare il vertice, sposta i vertici al proprietario del server del cluster di destinazione.

La seguente dichiarazione è la sintassi di base del comando Move Vertex.

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

Di seguito sono riportati i dettagli sulle opzioni nella sintassi precedente.

<source>- Definisce il vertice che si desidera spostare. Accetta l'ID record di un particolare vertice o array di ID record per i vertici.

<destination>- Definisce dove si desidera spostare il vertice. Supporta una classe o un cluster come destinazione.

SET - Imposta i valori sui campi.

MERGE - Imposta i valori sui campi tramite JSON.

BATCH - Definisce la dimensione del batch.

Note- Questo comando aggiorna tutti i bordi collegati, ma non i collegamenti. Quando si utilizza l'API Graph, si consiglia di utilizzare edge connesso ai vertici.

Esempio

Prova i seguenti esempi per imparare a spostare i vertici.

Eseguire la seguente query per spostare un singolo vertice con ID record # 11: 2 dalla sua posizione corrente a Class Employee.

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

Se la query precedente viene eseguita correttamente, otterrai il seguente output:

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

Eseguire la seguente query per spostare il set di vertici dalla classe "Customer" alla classe "Employee".

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

Se la query precedente viene eseguita correttamente, otterrai il seguente output.

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 Vertexcomando viene utilizzato per rimuovere i vertici dal database. Durante la cancellazione, controlla e mantiene la coerenza con i bordi e rimuove tutti i riferimenti incrociati (con i bordi) al vertice cancellato.

La seguente dichiarazione è la sintassi di base del comando Elimina vertice.

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

Di seguito sono riportati i dettagli sulle opzioni nella sintassi precedente.

<vertex> - Definisce il vertice che si desidera rimuovere, utilizzando la sua Classe, ID record o tramite una sottoquery.

WHERE - Filtra la condizione per determinare quali record vengono rimossi dal comando.

LIMIT - Definisce il numero massimo di record da rimuovere.

BATCH - Definisce il numero di record che il comando rimuove alla volta, consentendo di suddividere le transazioni di grandi dimensioni in blocchi più piccoli per risparmiare sull'utilizzo della memoria.

Esempio

Prova il seguente comando per imparare come eliminare un singolo vertice o più vertici.

Eseguire il seguente comando per rimuovere il vertice "# 14: 1".

orientdb> DELETE VERTEX #14:1

Se il comando precedente viene eseguito correttamente, otterrai il seguente output.

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

Esegui il seguente comando per rimuovere tutti i vertici dalla classe "Cliente" contrassegnata dalla proprietà "isSpam".

orientdb> DELETE VERTEX Customer WHERE isSpam = TRUE

Se il comando precedente viene eseguito correttamente, otterrai il seguente output.

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

In OrientDB, il concetto Edgefunziona come una relazione tra i vertici con l'aiuto di alcune proprietà. Bordi e vertici sono i componenti principali di un database a grafo. Applica il polimorfismo ai bordi. La classe di base per un Edge è E. Durante l'implementazione di bordi, se i vertici di origine o di destinazione mancano o non esistono, la transazione verrà ripristinata.

La seguente dichiarazione è la sintassi di base di Create Edge Command.

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

Di seguito sono riportati i dettagli sulle opzioni nella sintassi precedente.

<class> - Definisce il nome della classe per il bordo.

<cluster> - Definisce il cluster in cui si desidera memorizzare il bordo.

JSON - Fornisce contenuto JSON da impostare come record.

RETRY - Definisce il numero di tentativi da tentare in caso di conflitto.

WAIT - Definisce il tempo di ritardo tra i tentativi in ​​millisecondi.

BATCH - Definisce se suddivide il comando in blocchi più piccoli e la dimensione dei batch.

Esempio

Esegui la seguente query per creare un bordo E tra due vertici # 9: 0 e # 14: 0.

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

Se la query precedente viene eseguita correttamente, otterrai il seguente output.

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

Eseguire la seguente query per creare un nuovo tipo di bordo e un bordo di nuovo tipo.

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

Se la query precedente viene eseguita correttamente, otterrai il seguente output.

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

Update edgeviene utilizzato per aggiornare i record edge nel database corrente. Ciò equivale al comando di aggiornamento effettivo oltre a controllare e mantenere la coerenza del grafico con i vertici, nel caso in cui si aggiorni il fileout e in proprietà.

La seguente dichiarazione è la sintassi di base di Update Edge Command.

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

Di seguito sono riportati i dettagli sulle opzioni nella sintassi precedente.

<edge>- Definisce il bordo che si desidera aggiornare. Puoi scegliere traClass che aggiorna i bordi per classe, Cluster che aggiorna i bordi per cluster, utilizzando il prefisso CLUSTER, o Record ID che aggiorna i bordi per ID record.

SET - Aggiorna il campo ai valori dati.

INCREMENT - Incrementa il campo specificato del valore.

ADD - Definisce un elemento da aggiungere a una raccolta di campi.

REMOVE - Definisce un elemento da rimuovere da una raccolta di campi.

PUT - Definisce una voce da inserire nei campi della mappa.

RETURN - Definisce l'espressione che si desidera restituire dopo aver eseguito l'aggiornamento.

WHERE - Definisce la condizione del filtro.

LOCK - Definisce il modo in cui il record si blocca tra il caricamento e gli aggiornamenti.

LIMIT - Definisce il numero massimo di record.

Esempio

Consideriamo un esempio di aggiornamento del bordo denominato "indirizzo" nella classe persona prendendo i dati dalla tabella degli indirizzi con area Id = 001 e il nome della persona = Krishna.

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

Se la query precedente viene eseguita correttamente, otterrai il seguente output.

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

Delete edgecomando viene utilizzato per rimuovere il database. Questo è equivalente al comando di cancellazione, con l'aggiunta del controllo e del mantenimento della coerenza con i vertici rimuovendo tutti i riferimenti incrociati al bordo dalle proprietà dei vertici "in" e "out".

La seguente dichiarazione è la sintassi di base del comando Elimina Edge.

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

Di seguito sono riportati i dettagli sulle opzioni nella sintassi precedente.

FROM - Definisce il vertice del punto iniziale del bordo da eliminare.

To - Definisce il vertice del punto finale del bordo da eliminare.

WHERE - Definisce le condizioni di filtraggio.

LIMIT - Definisce il numero massimo di bordi da eliminare.

BATCH - Definisce la dimensione del blocco per l'operazione.

Esempio

Prova i seguenti esempi per imparare a eliminare i bordi.

Esegui la seguente query per eliminare il bordo tra due vertici (# 11: 2, # 11: 10). Ma potrebbe esserci una possibilità che potrebbero esistere uno o più bordi tra due vertici. Quindi stiamo usando la proprietà date per una corretta funzionalità. Questa query eliminerà i bordi creati su "2015-01-15' e più tardi.

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

Se la query precedente viene eseguita correttamente, otterrai il seguente output.

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

Esegui la seguente query per eliminare gli spigoli che iniziano dal vertice "# 11: 5" al vertice "# 11: 10" e che sono correlati a "classe = Cliente".

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

Se la query precedente viene eseguita correttamente, otterrai il seguente output.

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

Questo capitolo spiega il riferimento completo dei diversi tipi di funzioni in OrientDB. La tabella seguente definisce l'elenco delle funzioni, classificate in base alla loro funzionalità.

Funzioni grafiche

Sr.No. Nome e descrizione della funzione
1

Out():

Ottiene i vertici in uscita adiacenti a partire dal record corrente come Vertice.

Syntax - out ([<label-1>] [, <label-n>] *)

2

In():

Ottiene i vertici in entrata adiacenti a partire dal record corrente come Vertice.

Syntax - in ([<label-1>] [, <label-n>] *)

3

Both():

Ottiene i vertici adiacenti in uscita e in entrata a partire dal record corrente come Vertice.

Syntax - entrambi ([<label1>] [, <label-n>] *)

4

outE():

Ottiene i bordi in uscita adiacenti a partire dal record corrente come Vertice.

Syntax - outE ([<label1>] [, <label-n>] *)

5

inE():

Ottiene i bordi in entrata adiacenti a partire dal record corrente come Vertice.

Syntax - inE ([<label1>] [, <label-n>] *)

6

bothE():

Ottiene i bordi adiacenti in uscita e in entrata a partire dal record corrente come Vertice.

Syntax - bothE ([<label1>] [, <label-n>] *)

7

outV():

Ottiene i vertici in uscita a partire dal record corrente come Edge.

Syntax - outV ()

8

inV():

Ottieni i vertici in arrivo dal record corrente come Edge.

Syntax - inV ()

9

traversedElement():

Restituisce gli elementi attraversati nei comandi Traverse.

Syntax - traversedElement (<index> [, <items>])

10

traversedVertex():

Restituisce i vertici attraversati nei comandi Traverse.

Syntax - traversedVertex (<index> [, <items>])

11

traversedEdge():

Restituisce i bordi attraversati nei comandi Traverse.

Syntax - traversedEdge (<index> [, <items>])

12

shortestPath():

Restituisce il percorso più breve tra due vertici. La direzione può essere OUT (impostazione predefinita), IN o BOTH.

Synatx - shortestPath (<sourceVertex>, <destinationVertex> [, <direction> [, <edgeClassName>]])

13

dijkstra():

Restituisce il percorso più economico tra due vertici utilizzando l'algoritmo Dijkstra.

Syntax - dijkstra (<sourceVertex>, <destinationVertex>, <weightEdgeFieldName> [, <direction>])

Prova alcune funzioni grafiche insieme alle seguenti query.

Esegui la seguente query per ottenere tutti i vertici in uscita da tutti i vertici del veicolo.

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

Se la query precedente viene eseguita correttamente, otterrai il seguente output.

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

Esegui la seguente query per ottenere sia i vertici in entrata che quelli in uscita dal vertice # 11: 3.

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

Se la query precedente viene eseguita correttamente, otterrai il seguente output.

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

Funzioni matematiche

Sr.No. Nome e descrizione della funzione
1

eval():

Valuta l'espressione tra virgolette (o doppie virgolette).

Syntax - eval ('<espressione>')

2

min():

Restituisce il valore minimo. Se invocato con più di un parametro, restituisce il valore di argomento minimo tra tutti gli argomenti.

Syntax - min (<field> [, <field-n>] *)

3

max():

Restituisce il valore massimo. Se richiamato con più di un parametro, restituisce il valore massimo tra tutti gli argomenti.

Syntax - max (<field> [, <field-n>] *)

4

sum()

Restituisce la somma di tutti i valori restituiti.

Syntax - somma (<field>)

5

abs():

Restituisce il valore assoluto. Funziona con Integer, Long, Short, Double, Float, BigInteger, BigDecimal, null.

Syntax - abs (<field>)

6

avg():

Restituisce il valore medio.

Syntax - avg (<field>)

7

count():

Conta il record che corrisponde alla condizione della query. Se * non viene utilizzato come campo, il record verrà conteggiato solo se il contenuto non è nullo.

Syntax - count (<field>)

8

mode():

Restituisce il valore che si verifica con la frequenza maggiore. I valori nulli vengono ignorati nel calcolo.

Syntax - modalità (<field>)

9

median():

Restituisce il valore medio o un valore interpolato che rappresenta il valore centrale dopo che i valori sono stati ordinati. I valori nulli vengono ignorati nel calcolo.

Syntax - mediana (<field>)

10

percentile():

Restituisce l'ennesimo percentile. Null viene ignorato nel calcolo.

Syntax - percentile (<field> [, <quantile-n>] *)

11

variance()

Restituisce la varianza media: la media della differenza al quadrato dalla media.

Syntax - varianza (<field>)

12

stddev()

Restituisce la deviazione standard: la misura di quanto sono distribuiti i valori. I valori nulli vengono ignorati nel calcolo.

Syntax - stddev (<field>)

Prova alcune funzioni matematiche utilizzando le seguenti query.

Eseguire la seguente query per ottenere la somma degli stipendi di tutti i dipendenti.

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

Se la query precedente viene eseguita correttamente, otterrai il seguente output.

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

Eseguire la seguente query per ottenere lo stipendio medio di tutti i dipendenti.

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

Se la query precedente viene eseguita correttamente, otterrai il seguente output.

---+----------+--------- 
 # | @CLASS   | avg 
---+----------+--------- 
 0 | null     | 25 
---+----------+---------

Funzioni di raccolta

Sr.No. Nome e descrizione della funzione
1

set():

Aggiunge un valore a un set. Se il valore è una raccolta, viene unito al set, altrimenti viene aggiunto <valore>.

Syntax - set (<field>)

2

map():

Aggiunge un valore a una mappa la prima volta che viene creata la mappa. Se <valore> è una mappa, viene unita alla mappa, altrimenti la coppia <key> e <value> viene aggiunta alla mappa come nuova voce.

Syntax - mappa (<chiave>, <valore>)

3

ist():

Aggiunge un valore all'elenco la prima volta che l'elenco viene creato. Se <valore> è una raccolta, viene unito all'elenco, altrimenti <valore> viene aggiunto all'elenco.

Syntax - elenco (<field>)

4

difference():

Funziona come aggregato o in linea. Se viene passato un solo argomento, aggrega, altrimenti viene eseguito e restituisce la DIFFERENZA tra le raccolte ricevute come parametri.

Syntax - differenza (<field> [, <field-n>] *)

5

first():

Recupera solo il primo elemento dei campi multivalore (array, raccolte e mappe). Per i tipi non multivalore restituisce solo il valore.

Syntax - primo (<field>)

6

intersect():

Funziona come aggregato o in linea. Se viene passato un solo argomento, aggrega, altrimenti esegue e restituisce l'INTERAZIONE delle raccolte ricevute come parametri.

Syntax - intersecare (<field> [, <field-n>] *)

7

distinct():

Recupera solo voci di dati univoche a seconda del campo specificato come argomento. La principale differenza rispetto allo standard SQL DISTINCT è che con OrientDB è possibile specificare una funzione con parentesi e un solo campo.

Syntax - distinto (<field>)

8

expand():

Questa funzione ha due significati:

  • Quando viene utilizzato su un campo di raccolta, svolge la raccolta nel campo e lo utilizza come risultato.

  • Quando viene utilizzato su un campo di collegamento (RID), espande il documento puntato da quel collegamento.

Syntax - espandi (<field>)

9

unionall():

Funziona come aggregato o in linea. Se viene passato un solo argomento, aggrega, altrimenti esegue e restituisce un'UNIONE di tutte le raccolte ricevute come parametri. Funziona anche senza valori di raccolta.

Syntax - unionall (<field> [, <field-n>] *)

10

flatten():

Estrae la raccolta nel campo e la utilizza come risultato. È deprecato, usa invece expand ().

Syntax - appiattisci (<field>)

11

last():

Recupera solo l'ultimo elemento dei campi multivalore (array, raccolte e mappe). Per i tipi non multivalore restituisce solo il valore.

Syntax - ultimo (<field>)

12

symmetricDifference():

Funziona come aggregato o in linea. Se viene passato un solo argomento, aggrega, altrimenti esegue e restituisce la DIFFERENZA SIMMETRICA tra le raccolte ricevute come parametri.

Syntax - symmetricDifference (<field> [, <field-n>] *)

Prova alcune funzioni di raccolta utilizzando le seguenti query.

Esegui la seguente query per ottenere una serie di insegnanti, classe 9.

orientdb {db = demo}>SELECT ID, set(teacher.id) AS teacherID from classess where class_id = 9

Se la query precedente viene eseguita correttamente, otterrai il seguente output.

---+----------+--------+-------------------------- 
 # | @CLASS   | id     | TeacherID 
---+----------+--------+-------------------------- 
 0 | null     | 9     |   1201, 1202, 1205, 1208 
---+----------+-------+---------------------------

Funzioni varie

Sr.No. Nome e descrizione della funzione
1

date():

Restituisce una data formattando una stringa. <date-as-string> è la data in formato stringa e <format> è il formato della data che segue queste regole.

Syntax - data (<date-as-string> [<format>] [, <timezone>])

2

sysdate():

Restituisce la data e l'ora correnti.

Syntax - sysdate ([<format>] [, <timezone>])

3

format():

Formatta un valore utilizzando le convenzioni String.format ().

Syntax - formato (<format> [, <arg1>] (, <arg-n>] *. Md)

4

distance():

Restituisce la distanza tra due punti nel globo utilizzando l'algoritmo di Haversine. Le coordinate devono essere gradi.

Syntax - distanza (<x-field>, <y-field>, <x-value>, <y-value>)

5

ifnull():

Restituisce il campo / valore passato (o il parametro facoltativo return_value_if_not_null). Se il campo / valore non è nullo, restituisce return_value_if_null.

Syntax - ifnull (<field | value>, <return_value_if_null> [, <return_value_if_not_null>] (, <field & .md # 124; value>] *)

6

coalesce():

Restituisce il primo campo / valore non nullo. Se nessun campo / valore è diverso da null, restituisce null.

Syntax - coalesce (<campo | valore> [, <campo-n | valore-n>] *)

7

uuid():

Genera un UUID come valore a 128 bit utilizzando la variante Leach-Salz.

Syntax - uuid ()

8

if():

Valuta una condizione (primi parametri) e restituisce il secondo parametro se la condizione è vera, il terzo altrimenti.

Syntax - if (<espressione>, <result-if-true>, <result-if-false>)

Prova alcune funzioni Misc utilizzando le seguenti query.

Esegui la seguente query per imparare come eseguire if expression.

orientdb {db = demo}> SELECT if(eval("name = 'satish'"), "My name is satish", 
"My name is not satish") FROM Employee

Se la query precedente viene eseguita correttamente, otterrai il seguente output.

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

Eseguire la seguente query per ottenere la data di sistema.

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

Se la query precedente viene eseguita correttamente, otterrai il seguente output.

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

Utilizzando a fondo questa funzione è possibile manipolare facilmente i dati di OrientDB.

Sequencesè un concetto utilizzato nel meccanismo di incremento automatico ed è stato introdotto in OrientDB v2.2. Nella terminologia del database, la sequenza è una struttura che gestisce il campo del contatore. Detto semplicemente, le sequenze vengono utilizzate principalmente quando è necessario un numero che aumenta sempre. Supporta due tipi:

ORDERED - Ogni volta che il puntatore chiama il metodo .next che restituisce un nuovo valore.

CACHED- La sequenza memorizzerà nella cache "N" elementi su ciascun nodo. Per chiamare ogni articolo che usiamo.next(), che è preferibile quando la cache contiene più di un elemento.

Crea sequenza

La sequenza viene solitamente utilizzata per incrementare automaticamente il valore id di una persona. Come altri concetti SQL di OrientDB, esegue anche operazioni simili a Sequence in RDBMS.

La seguente dichiarazione è la sintassi di base per creare sequenze.

CREATE SEQUENCE <sequence> TYPE <CACHED|ORDERED> [START <start>]  
[INCREMENT <increment>] [CACHE <cache>]

Di seguito sono riportati i dettagli sulle opzioni nella sintassi precedente.

<Sequence> - Nome locale per la sequenza.

TYPE - Definisce il tipo di sequenza ORDERED o CACHED.

START - Definisce il valore iniziale.

INCREMENT - Definisce l'incremento per ogni chiamata al metodo .next.

CACHE - Definisce il numero di valore da pre-memorizzare nella cache, nel caso in cui sia stato utilizzato per memorizzare nella cache il tipo di sequenza.

Creiamo una sequenza denominata "seqid" che inizia con il numero 1201. Prova le seguenti query per implementare questo esempio con sequenza.

CREATE SEQUENCE seqid START 1201

Se la query precedente viene eseguita correttamente, otterrai il seguente output.

Sequence created successfully

Prova la seguente query per utilizzare la sequenza "seqid" per inserire il valore ID della tabella Account.

INSERT INTO Account SET id = sequence('seqid').next()

Se la query precedente viene eseguita correttamente, otterrai il seguente output.

Insert 1 record(s) in 0.001000 sec(s)

Alter Sequence

Alter sequence è un comando utilizzato per modificare le proprietà di una sequenza. Modificherà tutte le opzioni della sequenza tranne il tipo di sequenza.

La seguente dichiarazione è la sintassi di base per modificare la sequenza.

ALTER SEQUENCE <sequence> [START <start-point>] 
[INCREMENT <increment>] [CACHE <cache>]

Di seguito sono riportati i dettagli sulle opzioni nella sintassi precedente.

<Sequence> - Definisce la sequenza che si desidera modificare.

START - Definisce il valore iniziale.

INCREMENT - Definisce l'incremento per ogni chiamata al metodo .next.

CACHE - Definisce il numero di valore da pre-memorizzare nella cache nell'evento utilizzato per memorizzare nella cache il tipo di sequenza.

Prova la seguente query per modificare il valore iniziale da "1201 a 1000" di una sequenza denominata seqid.

ALTER SEQUENCE seqid START 1000

Se la query precedente viene eseguita correttamente, otterrai il seguente output.

Altered sequence successfully

Sequenza di rilascio

Rilascia sequenza è un comando utilizzato per rilasciare una sequenza.

La seguente dichiarazione è la sintassi di base per eliminare una sequenza.

DROP SEQUENCE <sequence>

Dove <Sequence> definisce la sequenza che si desidera eliminare.

Prova la seguente query per eliminare una sequenza denominata "seqid".

DROP SEQUENCE seqid

Se la query precedente viene eseguita correttamente, otterrai il seguente output.

Sequence dropped successfully

Index è un puntatore che punta a una posizione di dati nel database. Indexingè un concetto utilizzato per individuare rapidamente i dati senza dover cercare ogni record in un database. OrientDB supporta quattro algoritmi di indice e diversi tipi all'interno di ciascuno.

I quattro tipi di indice sono:

Indice SB-Tree

Fornisce una buona combinazione di funzionalità disponibili da altri tipi di indice. Meglio usarlo per utilità generale. È durevole, transazionale e supporta le query di intervallo. È il tipo di indice predefinito. I diversi tipi di plugin che supportano questo algoritmo sono:

  • UNIQUE- Questi indici non consentono chiavi duplicate. Per gli indici compositi, questo si riferisce all'unicità delle chiavi composite.

  • NOTUNIQUE - Questi indici consentono chiavi duplicate.

  • FULLTEXT- Questi indici si basano su una singola parola di testo. Puoi usarli nelle query tramiteCONTAINSTEXT operatore.

  • DICTIONARY - Questi indici sono simili a quelli che utilizzano UNIQUE, ma in caso di chiavi duplicate, sostituiscono il record esistente con il nuovo record.

Indice hash

Funziona più velocemente ed è molto leggero nell'utilizzo del disco. È durevole, transazionale, ma non supporta le query di intervallo. Funziona come HASHMAP, che lo rende più veloce nelle ricerche puntuali e consuma meno risorse rispetto ad altri tipi di indice. I diversi tipi di plugin che supportano questo algoritmo sono:

  • UNIQUE_HASH_INDEX- Questi indici non consentono chiavi duplicate. Per gli indici compositi, questo si riferisce all'unicità delle chiavi composite.

  • NOTUNIQUE_HASH_INDEX - Questi indici consentono chiavi duplicate.

  • FULLTEXT_HASH_INDEX- Questi indici si basano su una singola parola di testo. È possibile utilizzarli nelle query tramite l'operatore CONTAINSTEXT.

  • DICTIONARY_HASH_INDEX - Questi indici sono simili a quelli che utilizzano UNIQUE_HASH_INDEX, ma in caso di chiavi duplicate, sostituiscono il record esistente con il nuovo record.

Indice di testo completo di Lucene

Fornisce buoni indici full-text, ma non può essere utilizzato per indicizzare altri tipi. È durevole, transazionale e supporta le query di intervallo.

Indice spaziale Lucene

Fornisce buoni indici spaziali, ma non può essere utilizzato per indicizzare altri tipi. È durevole, transazionale e supporta le query di intervallo.

Creazione di indici

Crea indice è un comando per creare un indice su uno schema particolare.

La seguente dichiarazione è la sintassi di base per creare un indice.

CREATE INDEX <name> [ON <class-name> (prop-names)] <type> [<key-type>] 
[METADATA {<metadata>}]

Di seguito sono riportati i dettagli sulle opzioni nella sintassi precedente.

<name>- Definisce il nome logico per l'indice. È inoltre possibile utilizzare la notazione <class.property> per creare un indice automatico associato a una proprietà dello schema. <class> utilizza la classe dello schema e <property> utilizza la proprietà creata nella classe.

<class-name>- Fornisce il nome della classe che si sta creando l'indice automatico da indicizzare. Questa classe deve esistere nel database.

<prop-names>- Fornisce l'elenco delle proprietà che si desidera venga indicizzato dall'indice automatico. Queste proprietà devono già esistere nello schema.

<type> - Fornisce l'algoritmo e il tipo di indice che si desidera creare.

<key-type> - Fornisce il tipo di chiave opzionale con indici automatici.

<metadata> - Fornisce la rappresentazione JSON.

Esempio

Prova la seguente query per creare un indice automatico associato alla proprietà "ID" dell'utente sales_user.

orientdb> CREATE INDEX indexforID ON sales_user (id) UNIQUE

Se la query precedente viene eseguita correttamente, otterrai il seguente output.

Creating index... 
Index created successfully with 4 entries in 0.021000 sec(s)

Query sugli indici

È possibile utilizzare la query di selezione per ottenere i record nell'indice.

Prova la seguente query per recuperare le chiavi di indice denominate "indexforId".

SELECT FROM INDEX:indexforId

Se la query precedente viene eseguita correttamente, otterrai il seguente output.

----+------+----+----- 
#   |@CLASS|key |rid   
----+------+----+----- 
0   |null  |1   |#11:7 
1   |null  |2   |#11:6 
2   |null  |3   |#11:5 
3   |null  |4   |#11:8 
----+------+----+-----

Indici di rilascio

Se vuoi eliminare un particolare indice, puoi usare questo comando. Questa operazione non rimuove i record collegati.

La seguente dichiarazione è la sintassi di base per eliminare un indice.

DROP INDEX <name>

Dove <name> fornisce il nome dell'indice che si desidera eliminare.

Prova la seguente query per eliminare un indice denominato "ID" dell'utente sales_user.

DROP INDEX sales_users.Id

Se la query precedente viene eseguita correttamente, otterrai il seguente output.

Index dropped successfully

Come RDBMS, OrientDB supporta le proprietà ACID delle transazioni. UNtransactioncomprende un'unità di lavoro eseguita all'interno di un sistema di gestione di database. Esistono due ragioni principali per mantenere le transazioni in un ambiente di database.

  • Per consentire il ripristino simultaneo da errori e mantenere un database coerente anche in caso di errori di sistema.

  • Per fornire isolamento tra i programmi che accedono contemporaneamente a un database.

Per impostazione predefinita, la transazione del database deve seguire le proprietà ACID come le proprietà Atomic, Consistent, Isolated e Durable. Ma OrientDB è un database compatibile con ACID, il che significa che non contraddice o nega il concetto ACID, ma cambia la sua percezione durante la gestione del database NoSQL. Dai un'occhiata a come le proprietà ACID funzionano insieme al database NoSQL.

Atomic - Quando fai qualcosa per cambiare il database, la modifica dovrebbe funzionare o fallire nel suo complesso.

Consistent - Il database dovrebbe rimanere coerente.

Isolated - Se altre esecuzioni di transazioni sono in esecuzione contemporaneamente, l'utente non sarà in grado di vedere i record in esecuzione simultanea.

Durable - Se il sistema si blocca (hardware o software), il database stesso dovrebbe essere in grado di eseguire un backup.

La transazione del database può essere ottenuta utilizzando i comandi Commit e Rollback.

Commettere

Commit significa chiudere la transazione salvando tutte le modifiche al database. Rollback significa ripristinare lo stato del database fino al punto in cui è stata aperta la transazione.

La seguente dichiarazione è la sintassi di base del comando database COMMIT.

COMMIT

Note - È possibile utilizzare questo comando solo dopo essersi connessi a un determinato database e dopo aver iniziato la transazione.

Esempio

In questo esempio, useremo lo stesso database denominato "demo" che abbiamo creato in un capitolo precedente di questo tutorial. Vedremo l'operazione di commit della transazione e memorizzeremo un record usando le transazioni.

È necessario prima avviare la transazione utilizzando il seguente comando BEGIN.

orientdb {db = demo}> BEGIN

Inserisci un record in una tabella dei dipendenti con i valori id = 12 e name = satish.P utilizzando il seguente comando.

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

È possibile utilizzare il seguente comando per eseguire il commit della transazione.

orientdb> commit

Se questa transazione viene eseguita correttamente, otterrai il seguente output.

Transaction 2 has been committed in 4ms

Rollback

Rollback significa ripristinare lo stato del database fino al punto in cui è stata aperta la transazione.

La seguente dichiarazione è la sintassi di base del comando database ROLLBACK.

ROLLBACK

Note - È possibile utilizzare questo comando solo dopo essersi connessi a un determinato database e dopo aver iniziato la transazione.

Esempio

In questo esempio, useremo lo stesso database denominato "demo" che abbiamo creato in un capitolo precedente del tutorial. Vedremo l'operazione di rollback della transazione e memorizzeremo un record utilizzando le transazioni.

Devi prima avviare la transazione utilizzando il seguente comando BEGIN.

orientdb {db = demo}> BEGIN

Inserisci un record in una tabella dei dipendenti con i valori id = 12 e name = satish.P utilizzando il seguente comando.

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

È possibile utilizzare il seguente comando per recuperare i record del dipendente della tabella.

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

Se questo comando viene eseguito correttamente, otterrai il seguente output.

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

È possibile utilizzare il seguente comando per ripristinare questa transazione.

orientdb> ROLLBACK

Controllare di nuovo la query di selezione per recuperare lo stesso record dalla tabella Employee.

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

Se il rollback viene eseguito correttamente, si ottengono 0 record trovati nell'output.

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

OrientDB Hooksnon sono altro che trigger nella terminologia del database che abilitano eventi interni prima e dopo ogni operazione CRUD nelle applicazioni utente. È possibile utilizzare hook per scrivere regole di convalida personalizzate, per rafforzare la sicurezza o per organizzare eventi esterni come la replica su un DBMS relazionale.

OrientDB supporta due tipi di hook:

Dynamic Hook - Trigger, che possono essere costruiti a livello di classe e / o a livello di documento.

Java (Native) Hook - Trigger, che possono essere creati utilizzando classi Java.

Ganci dinamici

Gli hook dinamici sono più flessibili degli hook Java, perché possono essere modificati in fase di runtime e possono essere eseguiti per documento se necessario, ma sono più lenti degli hook Java.

Per eseguire hook sui tuoi documenti, prima consenti alle tue classi di estendersi OTriggeredclasse base. Successivamente, definire una proprietà personalizzata per l'evento interessato. Di seguito sono riportati gli eventi disponibili.

  • onBeforeCreate - Chiamato before creazione di un nuovo documento.

  • onAfterCreate - Chiamato after creazione di un nuovo documento.

  • onBeforeRead - Chiamato before leggere un documento.

  • onAfterRead - Chiamato after leggere un documento.

  • onBeforeUpdate - Chiamato before aggiornare un documento.

  • onAfterUpdate - Chiamato after aggiornare un documento.

  • onBeforeDelete - Chiamato before l'eliminazione di un documento.

  • onAfterDelete - Chiamato after l'eliminazione di un documento.

Gli hook dinamici possono chiamare -

  • Funzioni, scritte in SQL, Javascript o qualsiasi linguaggio supportato da OrientDB e JVM.

  • Metodi statici Java.

Ganci a livello di classe

Gli hook a livello di classe sono definiti per tutti i documenti relativi a una classe. Di seguito è riportato un esempio per impostare un hook che agisce a livello di classe contro i documenti Invoice.

CREATE CLASS Invoice EXTENDS OTriggered 
ALTER CLASS Invoice CUSTOM onAfterCreate = invoiceCreated

Creiamo la funzione invoiceCreated in Javascript che stampa nella console del server il numero della fattura creata.

CREATE FUNCTION invoiceCreated "print('\\nInvoice created: ' + doc.field ('number'));"
LANGUAGE Javascript

Ora prova il gancio creando un nuovo file Invoice documento.

INSERT INTO Invoice CONTENT {number: 100, notes: 'This is a test}

Se questo comando viene eseguito correttamente, otterrai il seguente output.

Invoice created: 100

Gancio a livello di documento

È possibile definire un'azione speciale solo su uno o più documenti. Per fare ciò, consenti alla tua classe di estendersiOTriggered classe.

Ad esempio, eseguiamo un trigger, come funzione Javascript, contro una classe Profile esistente, per tutti i documenti con account di proprietà = 'Premium'. Verrà chiamato il trigger per impedire la cancellazione dei documenti.

ALTER CLASS Profile SUPERCLASS OTriggered UPDATE Profile 
SET onBeforeDelete = 'preventDeletion' WHERE account = 'Premium'

Creiamo il file preventDeletion() Funzione Javascript.

CREATE FUNCTION preventDeletion "throw new java.lang.RuntimeException('Cannot 
delete Premium profile ' + doc)" LANGUAGE Javascript

Quindi prova l'hook provando a eliminare un account "Premium".

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

Ganci JAVA

Un caso d'uso comune per OrientDB Hooks (trigger) è quello di gestire le date create e aggiornate per una o tutte le classi. Ad esempio, puoi impostare un fileCreatedDate ogni volta che viene creato un record e impostare un UpdatedDate ogni volta che un record viene aggiornato, e farlo in un modo in cui si implementa la logica una volta a livello di database e non ci si deve più preoccupare di essa a livello di applicazione.

Prima di creare, dovrai scaricare orientdb-core.jarfile visitando il seguente link scarica OrientDB core . E successivamente copia quel file jar nella cartella in cui desideri memorizzare il file sorgente Java.

Crea file hook

Crea un file Java denominato HookTest.java, che testerà il meccanismo Hook utilizzando il linguaggio 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;  
   }  
}

Il codice di esempio precedente stampa il commento appropriato ogni volta che si crea o si aggiorna un record di quella classe.

Aggiungiamo un altro file hook setCreatedUpdatedDates.java come segue -

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; 
      } 
   }  
}

Quello che fa il codice sopra è cercare qualsiasi classe che inizi con le lettere 'r' o 't'e imposta CreatedDate e UpdatedDate quando il record viene creato e imposta solo UpdatedDate ogni volta che il record viene aggiornato.

Compila Java Hooks

Compilare il codice Java utilizzando il seguente comando. Note: Mantieni il file jar scaricato e questi file Java nella stessa cartella.

$ jar cf hooks-1.0-SNAPSHOT.jar *.java

Spostare il codice compilato dove il server OrientDB può trovarlo

È necessario copiare il file .jar finito nella directory in cui il server OrientDB li cercherà. Ciò significa che il './lib'nella directory principale del server OrientDB sarà simile a questa:

$ cp hooks-1.0-SNAPSHOT.jar "$ORIENTDB_HOME/lib"

Abilita Test Hook nel file di configurazione del server OrientDB

modificare $ORIENTDB_HOME/config/orientdb-server-config.xml e aggiungi la seguente sezione verso la fine del file.

<hooks> 
      <hook class = "HookTest" position = "REGULAR"/> 
   </hooks> 
   ... 
</orient-server>

Riavvia OrientDB Server

Dopo aver riavviato OrientDB Server, l'hook in cui hai definito orientdb-server-config.xmlè ora attivo. Avvia una console OrientDB, collegala al tuo database ed esegui il seguente comando:

INSERT INTO V SET ID = 1;

Se questo comando viene eseguito correttamente, otterrai il seguente output.

Ran create hook

Ora esegui il seguente comando:

UPDATE V SET ID = 2 WHERE ID = 1;

Se questo comando viene eseguito correttamente, otterrai il seguente output.

Ran update hook

Abilita Real Hook nel file di configurazione del server OrientDB

modificare $ORIENTDB_HOME/config/orientdb-server-config.xml e cambiare la sezione dei ganci come segue:

<hooks> 
      <hook class="setCreatedUpdatedDates" position="REGULAR"/> 
   </hooks> 
   ... 
</orient-server>

Riavvia OrientDB Server

Crea una nuova classe che inizi con la lettera 'r' o 't'-

CREATE CLASS tTest EXTENDS V;

Ora inserisci un record -

INSERT INTO tTest SET ID = 1 
SELECT FROM tTest

Se questo comando viene eseguito correttamente, otterrai il seguente output.

----+-----+------+----+-----------+----------- 
#   |@RID |@CLASS|ID  |CreatedDate|UpdatedDate 
----+-----+------+----+-----------+----------- 
0   |#19:0|tTest |1   |1427597275 |1427597275 
----+-----+------+----+-----------+-----------

Anche se non hai specificato valori da impostare CreatedDate e UpdatedDate, OrientDB ha impostato questi campi automaticamente per te.

Successivamente è necessario aggiornare il record utilizzando il seguente comando:

UPDATE tTest SET ID = 2 WHERE ID = 1; 
SELECT FROM tTest;

Se questo comando viene eseguito correttamente, otterrai il seguente output.

----+-----+------+----+-----------+----------- 
#   |@RID |@CLASS|ID  |CreatedDate|UpdatedDate 
----+-----+------+----+-----------+----------- 
0   |#19:0|tTest |2   |1427597275 |1427597306 
----+-----+------+----+-----------+-----------

Puoi vedere che OrientDB ha cambiato il file UpdatedDate ma ha lasciato il CreatedDate rimane invariato.

OrientDB Java Hooks può essere uno strumento estremamente prezioso per aiutare ad automatizzare il lavoro che altrimenti dovreste fare nel codice dell'applicazione. Poiché molti amministratori di database non sono sempre esperti di Java, si spera che le informazioni contenute in questo tutorial ti daranno un vantaggio e ti faranno sentire a tuo agio con la tecnologia, consentendoti di creare con successo trigger di database in caso di necessità.

Cachingè un concetto che creerà una copia della struttura della tabella del database fornendo un ambiente confortevole per le applicazioni utente. OrientDB ha diversi meccanismi di memorizzazione nella cache a diversi livelli.

La figura seguente fornisce un'idea di cosa sia la memorizzazione nella cache.

Nell'illustrazione sopra DB1, DB2, DB3 sono le tre diverse istanze di database utilizzate in un'applicazione.

Level-1 cache è un file Local cacheche memorizza tutte le entità conosciute da una specifica sessione. Se hai tre transazioni in questa sessione, conterrà tutte le entità utilizzate da tutte e tre le transazioni. Questa cache viene cancellata quando chiudi la sessione o quando esegui il metodo "clear". Riduce il carico delle operazioni di I / O tra l'applicazione e il database e, a sua volta, aumenta le prestazioni.

Level-2 cache è un file Real cacheche funziona utilizzando provider di terze parti. Puoi avere il pieno controllo del contenuto della cache, cioè sarai in grado di specificare quali voci devono essere rimosse, quali devono essere conservate più a lungo e così via. È una cache condivisa completa tra più thread.

Storage model non è altro che un dispositivo di archiviazione che è disco, memoria o server remoto.

Come funziona la cache in OrientDB?

La memorizzazione nella cache di OrientDB fornisce metodologie diverse in ambienti diversi. La memorizzazione nella cache viene utilizzata principalmente per transazioni di database più veloci, riducendo il tempo di elaborazione di una transazione e aumentando le prestazioni. I seguenti diagrammi di flusso mostrano come funziona la memorizzazione nella cache in modalità locale e in modalità client-server.

Modalità locale (database incorporato)

Il diagramma di flusso seguente indica come il record si trova tra l'archiviazione e l'applicazione utilizzata in modalità locale, ovvero quando il server del database si trova nell'host locale.

Quando l'applicazione client richiede un record, OrientDB controlla quanto segue:

  • Se una transazione è iniziata, cerca all'interno della transazione i record modificati e li restituisce se trovati.

  • Se la cache locale è abilitata e contiene il record richiesto, lo restituisce.

  • Se a questo punto il record non è in cache, lo richiede allo Storage (disco, memoria).

Modalità server client (database remoto)

Il diagramma di flusso seguente indica come il record si trova tra l'archiviazione e l'applicazione utilizzata in modalità client-server, ovvero quando il server del database si trova in una posizione remota.

Quando l'applicazione client richiede un record, OrientDB verifica quanto segue:

  • Se una transazione è iniziata, cerca all'interno della transazione i record modificati e li restituisce se trovati.

  • Se la cache locale è abilitata e contiene il record richiesto, lo restituisce.

  • A questo punto, se il record non è in cache, lo richiede al Server tramite una chiamata TCP / IP.

  • Nel server, se la cache locale è abilitata e contiene il record richiesto, lo restituisce.

  • A questo punto, ancora il record non viene memorizzato nella cache del server, quindi lo richiede allo Storage (disco, memoria).

OrientDB utilizza il framework di registrazione Java in bundle con Java Virtual Machine. Il formato di registro predefinito di OrientDB è gestito daOLogFormatter classe.

La seguente dichiarazione è la sintassi di base del comando di registrazione.

<date> <level> <message> [<requester>]

Di seguito sono riportati i dettagli sulle opzioni nella sintassi precedente.

<date> - È la data del registro nel seguente formato: aaaa-MM-gg HH: mm: ss: SSS.

<level> - È il livello di registrazione come output di 5 caratteri.

<message> - È il testo del registro, può essere di qualsiasi dimensione.

[<class>] - È la classe Java che viene registrata (opzionale).

I livelli supportati sono quelli contenuti nella classe JRE java.util.logging.Level. Sono -

  • SEVERE (valore più alto)
  • WARNING
  • INFO
  • CONFIG
  • FINE
  • FINER
  • FINEST (valore più basso)

Per impostazione predefinita, sono installati due logger:

  • Console, come output della shell / prompt dei comandi che avvia l'applicazione / il server. Può essere modificato impostando la variabile "log.console.level".

  • File, come output nei file di registro. Può essere modificato impostando "log.file.level".

Configura registrazione

Le strategie e le politiche di registrazione possono essere configurate utilizzando un file che segue Java.

syntax - Configurazione Java Logging.

Esempio

Copia il seguente contenuto da orientdb-server-log.properties file e inseriscilo nel file $ORIENTDB_HOME/config file.

# 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

Per indicare alla JVM dove si trova il file delle proprietà, è necessario impostare "java.util.logging.config.file"proprietà di sistema. Ad esempio, utilizza il seguente comando:

$ java -Djava.util.logging.config.file=mylog.properties ...

Imposta il livello di registrazione

Per modificare il livello di registrazione senza modificare la configurazione della registrazione, è sufficiente impostare il "log.console.level" e "log.file.level"variabili di sistema ai livelli richiesti.

Registrazione all'avvio

Di seguito sono riportate le procedure per impostare la registrazione a livello di avvio in diversi modi.

Nella configurazione del server

Apri il file orientdb-server-config.xml e aggiungi o aggiorna queste righe alla fine del file all'interno della sezione <properties> -

<entry value = "fine" name = "log.console.level" /> 
<entry value = "fine" name = "log.file.level" />

Nello script Server.sh (o .bat)

Imposta la proprietà di sistema "log.console.level" e "log.file.level"ai livelli desiderati utilizzando il parametro -D di java.

$ java -Dlog.console.level = FINE ...

Registrazione in fase di esecuzione

Di seguito sono riportate le procedure per impostare la registrazione a livello di avvio in diversi modi.

Utilizzando il codice Java

La variabile di sistema può essere impostata all'avvio utilizzando l'API System.setProperty (). Il seguente frammento di codice è la sintassi per impostare il livello di registrazione utilizzando il codice Java.

public void main(String[] args){ 
   System.setProperty("log.console.level", "FINE"); 
   ... 
}

Su server remoto

Esegui un POST HTTP sull'URL: /server/log.<type>/ <level>, dove -

  • <tipo> può essere "console" o "file"
  • <level> è uno dei livelli supportati

Esempio

Il seguente esempio usa cURLper eseguire un comando HTTP POST su OrientDB Server. Sono stati utilizzati l'utente "root" e la password del server, sostituiti con la tua password.

Abilita il miglior livello di tracciamento alla console -

curl -u root:root -X POST http://localhost:2480/server/log.console/FINEST

Abilita il miglior livello di tracciamento al file -

curl -u root:root -X POST http://localhost:2480/server/log.file/FINEST

In questo capitolo, puoi ottenere alcuni suggerimenti generali su come ottimizzare la tua applicazione che usa OrientDB. Esistono tre modi per aumentare le prestazioni per diversi tipi di database.

  • Document Database Performance Tuning - Utilizza una tecnica che aiuta a evitare la creazione di documenti per ogni nuovo documento.

  • Object Database Performance Tuning - Utilizza le tecniche generiche per migliorare le prestazioni.

  • Distributed Configuration Tuning - Utilizza diverse metodologie per migliorare le prestazioni nella configurazione distribuita.

È possibile ottenere l'ottimizzazione delle prestazioni generiche modificando le impostazioni di Memoria, JVM e Connessione remota.

Impostazioni di memoria

Esistono diverse strategie nell'impostazione della memoria per migliorare le prestazioni.

Impostazioni server e incorporate

Queste impostazioni sono valide sia per il componente Server che per la JVM in cui l'applicazione Java viene eseguita utilizzando OrientDB in modalità Embedded, utilizzando direttamente plocal.

La cosa più importante durante la messa a punto è assicurarsi che le impostazioni della memoria siano corrette. Ciò che può fare davvero la differenza è il giusto bilanciamento tra l'heap e la memoria virtuale utilizzata da Memory Mapping, specialmente su set di dati di grandi dimensioni (GB, TB e altro) dove le strutture della cache in memoria contano meno dell'IO grezzo.

Ad esempio, se è possibile assegnare un massimo di 8 GB al processo Java, di solito è meglio assegnare un piccolo heap e un grande buffer della cache del disco (memoria fuori heap).

Prova il seguente comando per aumentare la memoria heap.

java -Xmx800m -Dstorage.diskCache.bufferSize=7200 ...

Il storage.diskCache.bufferSize impostazione (con il vecchio archivio "locale" era file.mmap.maxMemory) è in MB e indica la quantità di memoria da utilizzare per il componente Disk Cache. Per impostazione predefinita è 4 GB.

NOTE - Se la somma dell'heap massimo e del buffer della cache del disco è troppo alta, il sistema operativo potrebbe cambiare con un enorme rallentamento.

Impostazioni JVM

Le impostazioni JVM sono codificate in file batch server.sh (e server.bat). È possibile modificarli per regolare la JVM in base all'utilizzo e alle impostazioni hw / sw. Aggiungi la seguente riga nel file server.bat.

-server -XX:+PerfDisableSharedMem

Questa impostazione disabiliterà la scrittura delle informazioni di debug sulla JVM. Nel caso in cui sia necessario creare il profilo della JVM, è sufficiente rimuovere questa impostazione.

Connessioni remote

Esistono molti modi per migliorare le prestazioni quando si accede al database utilizzando una connessione remota.

Recupero della strategia

Quando lavori con un database remoto devi prestare attenzione alla strategia di recupero utilizzata. Per impostazione predefinita, il client OrientDB carica solo il record contenuto nel gruppo di risultati. Ad esempio, se una query restituisce 100 elementi, ma se si incrociano questi elementi dal client, il client OrientDB carica pigramente gli elementi con un'altra chiamata di rete al server per ogni record mancato.

Pool di connessioni di rete

Ogni client, per impostazione predefinita, utilizza solo una connessione di rete per parlare con il server. Più thread sullo stesso client condividono lo stesso pool di connessioni di rete.

Quando si hanno più thread, potrebbe esserci un collo di bottiglia poiché molto tempo viene speso in attesa di una connessione di rete gratuita. Questo è il motivo per cui è importante configurare il pool di connessioni di rete.

La configurazione è molto semplice, solo 2 parametri -

  • minPool- È la dimensione iniziale del pool di connessioni. Il valore predefinito è configurato come parametri globali "client.channel.minPool".

  • maxPool- È la dimensione massima che il pool di connessioni può raggiungere. Il valore predefinito è configurato come parametri globali "client.channel.maxPool".

Se tutte le connessioni del pool sono occupate, il thread del client attenderà la prima connessione libera.

Comando di esempio di configurazione utilizzando le proprietà del database.

database = new ODatabaseDocumentTx("remote:localhost/demo"); 
database.setProperty("minPool", 2); 
database.setProperty("maxPool", 5);  

database.open("admin", "admin");

Ottimizzazione della configurazione distribuita

Esistono molti modi per migliorare le prestazioni nella configurazione distribuita.

Usa transazioni

Anche quando aggiorni i grafici, dovresti sempre lavorare sulle transazioni. OrientDB ti consente di lavorare al di fuori di essi. I casi comuni sono query di sola lettura o operazioni massicce e non simultanee possono essere ripristinate in caso di errore. Quando si esegue su una configurazione distribuita, l'utilizzo delle transazioni aiuta a ridurre la latenza. Questo perché l'operazione distribuita avviene solo al momento del commit. La distribuzione di una grande operazione è molto efficiente rispetto al trasferimento di piccole operazioni multiple, a causa della latenza.

Replica vs Sharding

La configurazione distribuita di OrientDB è impostata sulla replica completa. Avere più nodi con la stessa copia del database è importante per le letture in scala. In effetti, ogni server è indipendente dall'esecuzione di letture e query. Se si dispone di 10 nodi del server, la velocità effettiva di lettura è 10x.

Con le scritture, è l'opposto: avere più nodi con replica completa rallenta le operazioni, se la replica è sincrona. In questo caso, il partizionamento orizzontale del database su più nodi consente di aumentare la scala delle scritture, poiché solo un sottoinsieme di nodi è coinvolto nella scrittura. Inoltre, potresti avere un database più grande di un nodo server HD.

Aumenta la scala sulle scritture

Se disponi di una rete lenta e hai una replica sincrona (predefinita), potresti pagare il costo della latenza. Infatti, quando OrientDB viene eseguito in modo sincrono, attende almeno il filewriteQuorum. Ciò significa che se writeQuorum è 3 e si hanno 5 nodi, il nodo del server coordinatore (dove viene avviata l'operazione distribuita) deve attendere la risposta da almeno 3 nodi per fornire la risposta al client.

Per mantenere la coerenza, writeQuorum dovrebbe essere impostato sulla maggioranza. Se hai 5 nodi la maggioranza è 3. Con 4 nodi, è ancora 3. L'impostazione di writeQuorum su 3 invece di 4 o 5 consente di ridurre il costo di latenza e mantenere comunque la coerenza.

Replica asincrona

Per velocizzare le cose, puoi configurare la replica asincrona per rimuovere il collo di bottiglia della latenza. In questo caso, il nodo del server coordinatore esegue l'operazione localmente e fornisce la risposta al client. L'intera replica sarà in background. Nel caso in cui il quorum non venga raggiunto, le modifiche verranno annullate in modo trasparente.

Aumenta le letture

Se hai già impostato writeQuorum sulla maggior parte dei nodi, puoi lasciare il readQuoruma 1 (impostazione predefinita). Questo accelera tutte le letture.

Durante l'aggiornamento, devi considerare il numero di versione e il formato. Esistono tre tipi di formati: MAJOR, MINOR, PATCH.

  • MAJOR la versione comporta modifiche API incompatibili.

  • MINOR versione comporta funzionalità in modo compatibile con le versioni precedenti.

  • PTCH versione comporta correzioni di bug compatibili con le versioni precedenti.

Per sincronizzare tra le versioni minori e principali, potrebbe essere necessario esportare e importare i database. A volte molti hanno bisogno di migrare il database da LOCAL a PLOCAL e hanno bisogno di migrare il grafico a RidBag.

Migrazione da LOCAL Storage Engine a PLOCAL

A partire dalla versione 1.5.x OrientDB viene fornito con un nuovissimo motore di archiviazione: PLOCAL (Impaginato LOCALE). È persistente come il LOCAL, ma memorizza le informazioni in modo diverso. I seguenti punti mostrano il confronto tra PLOCAL e LOCAL -

  • In PLOCAL i record sono archiviati in file cluster, mentre con LOCAL è stato suddiviso tra cluster e segmenti di dati.

  • PLOCAL è più durevole di LOCAL a causa della modalità di aggiunta in scrittura.

  • PLOCAL ha blocchi di contesa minori sulle scritture, il che significa più concorrenza.

  • PLOCAL non utilizza tecniche di Memory Mapping (MMap) quindi il comportamento è più "prevedibile".

Per migrare il tuo archivio LOCALE nel nuovo PLOCAL, devi esportare e reimportare il database utilizzando PLOCAL come motore di archiviazione. Di seguito è la procedura.

Step 1 - Apri una nuova shell (Linux / Mac) o un prompt dei comandi (Windows).

Step 2- Esporta il database utilizzando la console. Segui il comando indicato per esportare la demo del database indemo.json.gzip file.

$ 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 - Su un filesystem locale, crea un nuovo database usando il motore "plocal" -

orientdb> CREATE DATABASE plocal:/temp/newdb admin admin plocal graph

Step 4 - Importa il vecchio database in quello nuovo.

orientdb> IMPORT DATABASE /temp/demo.json.gzip -preserveClusterIDs=true 
orientdb> QUIT

Se accedi al database nella stessa JVM, ricorda di cambiare l'URL da "local:" a "plocal:"

Migrare Graph a RidBag

A partire da OrientDB 1.7, RidBag è una raccolta predefinita che gestisce le relazioni di adiacenza nei grafici. Sebbene i database precedenti gestiti da un MVRB-Tree siano completamente compatibili, è possibile aggiornare il database al formato più recente.

Puoi aggiornare il tuo grafico tramite console o utilizzando il ORidBagMigration classe.

  • Connetti al database CONNECT plocal:databases/<graphdb-name>

  • Esegui il comando di aggiornamento del grafico

Come RDBMS, anche OrientDB fornisce sicurezza basata su concetti, utenti e ruoli ben noti. Ogni database ha i propri utenti e ogni utente ha uno o più ruoli. I ruoli sono la combinazione di modalità di lavoro e set di autorizzazioni.

Utenti

Per impostazione predefinita, OrientDB mantiene tre diversi utenti per tutti i database nel server -

  • Admin - Questo utente ha accesso a tutte le funzioni del database senza limitazioni.

  • Reader- Questo utente è un utente di sola lettura. Il lettore può interrogare qualsiasi record nel database, ma non può modificarli o eliminarli. Non ha accesso alle informazioni interne, come gli utenti e i ruoli stessi.

  • Writer - Questo utente è uguale al lettore utente, ma può anche creare, aggiornare ed eliminare record.

Lavorare con gli utenti

Quando si è connessi a un database, è possibile interrogare gli utenti correnti nel database utilizzando SELECT query su OUser classe.

orientdb> SELECT RID, name, status FROM OUser

Se la query precedente viene eseguita correttamente, otterrai il seguente output.

---+--------+--------+-------- 
#  | @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).

Creazione di un nuovo utente

Per creare un nuovo utente, usa il comando INSERT. Ricorda, così facendo, devi impostare lo stato su ATTIVO e assegnargli un ruolo valido.

orientdb> INSERT INTO OUser SET 
               name = 'jay', 
               password = 'JaY',
               status = 'ACTIVE',
               roles = (SELECT FROM ORole WHERE name = 'reader')

Aggiornamento degli utenti

È possibile modificare il nome per l'utente con l'istruzione UPDATE.

orientdb> UPDATE OUser SET name = 'jay' WHERE name = 'reader'

Allo stesso modo, puoi anche cambiare la password per l'utente.

orientdb> UPDATE OUser SET password = 'hello' WHERE name = 'reader'

OrientDB salva la password in un formato hash. Il grillettoOUserTrigger crittografa la password in modo trasparente prima di salvare il record.

Disabilitazione degli utenti

Per disabilitare un utente, utilizzare UPDATE per cambiare il suo stato da ATTIVO a SOSPESO. Ad esempio, se desideri disabilitare tutti gli utenti ad eccezione dell'amministratore, utilizza il seguente comando:

orientdb> UPDATE OUser SET status = 'SUSPENDED' WHERE name <> 'admin'

Ruoli

Un ruolo determina le operazioni che un utente può eseguire su una risorsa. Principalmente, questa decisione dipende dalla modalità di lavoro e dalle regole. Le regole stesse funzionano in modo diverso, a seconda della modalità di lavoro.

Lavorare con i ruoli

Quando si è connessi a un database, è possibile interrogare i ruoli correnti nel database utilizzando SELECT query su ORole classe.

orientdb> SELECT RID, mode, name, rules FROM ORole

Se la query precedente viene eseguita correttamente, otterrai il seguente output.

--+------+----+--------+------------------------------------------------------- 
# |@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).

Creazione di nuovi ruoli

Per creare un nuovo ruolo, utilizzare l'istruzione INSERT.

orientdb> INSERT INTO ORole SET name = 'developer', mode = 0

Lavorare con le modalità

Laddove le regole determinano ciò che gli utenti appartenenti a determinati ruoli possono fare sui database, le modalità di lavoro determinano il modo in cui OrientDB interpreta queste regole. Esistono due tipi di modalità di lavoro, designate da 1 e 0.

  • Allow All But (Rules)- Per impostazione predefinita è la modalità super utente. Specificare le eccezioni a questo utilizzando le regole. Se OrientDB non trova regole per una risorsa richiesta, consente all'utente di eseguire l'operazione. Utilizzare questa modalità principalmente per utenti esperti e amministratori. Il ruolo predefinito admin utilizza questa modalità per impostazione predefinita e non ha regole di eccezione. È scritto come 1 nel database.

  • Deny All But (Rules)- Per impostazione predefinita questa modalità non consente nulla. Specificare le eccezioni a questo utilizzando le regole. Se OrientDB trova le regole per una risorsa richiesta, consente all'utente di eseguire l'operazione. Usa questa modalità come predefinita per tutti gli utenti classici. I ruoli predefiniti, lettore e scrittore, utilizzano questa modalità. È scritto come 0 nel database.

OrientDB fornisce un'interfaccia utente web per eseguire operazioni di database tramite GUI. Questo capitolo spiega le diverse opzioni disponibili in OrientDB.

Home page di Studio

Studio è un'interfaccia web per l'amministrazione di OrientDB fornita in bundle con la distribuzione OrientDB.

Innanzitutto, è necessario avviare il server OrientDB utilizzando il seguente comando.

$ server.sh

Se esegui OrientDB nella tua macchina, è possibile accedere all'interfaccia web tramite l'URL -

http://localhost:2480

Se il comando viene eseguito correttamente, il seguente sarà l'output sullo schermo.

Connettiti a un database esistente

Per accedere, selezionare un database dall'elenco dei database e utilizzare qualsiasi utente del database. Per impostazione predefinita (nome utente / password)reader/reader può leggere i record dal database, writer/writer può leggere, creare, aggiornare ed eliminare record, mentre admin/admin ha tutti i diritti.

Elimina un database esistente

Seleziona un database dall'elenco dei database e fai clic sull'icona del cestino. Studio aprirà un popup di conferma in cui è necessario inserire l'utente del server e la password del server.

Quindi fare clic sul pulsante "Elimina database". Puoi trovare le credenziali del server nel file$ORIENTDB_HOME/config/orientdb-server-config.xml file.

<users> 
   <user name = "root" password = "pwd" resources = "*" /> 
</users>

Crea un nuovo database

Per creare un nuovo database, fare clic sul pulsante "Nuovo DB" dalla home page.

Le seguenti informazioni sono necessarie per creare un nuovo database:

  • Nome del database
  • Tipo di database (documento / grafico)
  • Tipo di archiviazione (locale / memoria)
  • Utente server
  • Password del server

Puoi trovare le credenziali del server nel file $ORIENTDB_HOME/config/orientdbserver-config.xml file.

<users> 
   <user name = "root" password = "pwd" resources = "*" /> 
</users>

Una volta creato, Studio accederà automaticamente al nuovo database.

Esegui una query

Studio supporta il riconoscimento automatico della lingua che stai utilizzando tra quelle supportate: SQL e Gremlin. Durante la scrittura, utilizzare la funzione di completamento automatico premendoCtrl + Space.

Le seguenti scorciatoie sono disponibili nell'editor delle query:

  • Ctrl + Return - Per eseguire la query o semplicemente fare clic su Run pulsante.

  • Ctrl/Cmd + Z - Per annullare le modifiche.

  • Ctrl/Cmd + Shift + Z - Per rifare le modifiche.

  • Ctrl/Cmd + F - Per cercare nell'editor.

  • Ctrl/Cmd + / - Per attivare o disattivare un commento.

Lo screenshot seguente mostra come eseguire una query.

Facendo clic su qualsiasi @rid valore nel set di risultati, entrerai in modalità di modifica del documento se il record è un documento, altrimenti entrerai in modifica del vertice.

Puoi aggiungere le tue query ai preferiti facendo clic sull'icona a forma di stella nel set di risultati o nell'editor. Per sfogliare le query inserite nei segnalibri, fare clic suBookmarkspulsante. Studio aprirà l'elenco dei segnalibri sulla sinistra, dove puoi modificare / eliminare o rieseguire le query.

Studio salva le query eseguite nella memoria locale del browser. Nelle impostazioni della query, puoi configurare il numero di query che Studio conserverà nella cronologia. È anche possibile cercare una query eseguita in precedenza, eliminare tutte le query dalla cronologia o eliminare una singola query.

Modifica vertice

Per modificare il vertice del grafico, vai alla sezione Grafico. Quindi eseguire la seguente query.

Select From Customer

Dopo aver eseguito con successo la query, segue lo screenshot dell'output. Selezionare il particolare vertice nell'area di disegno del grafico da modificare.

Seleziona il simbolo di modifica sul vertice particolare. Apparirà la seguente schermata che contiene le opzioni per modificare il vertice.

Schema Manager

OrientDB può funzionare in modalità senza schema, modalità schema o una combinazione di entrambi. Qui discuteremo la modalità schema. Fare clic sulla sezione Schema nella parte superiore dell'interfaccia utente Web. Otterrai il seguente screenshot.

Crea una nuova classe

Per creare una nuova classe, fai clic su New Classpulsante. Apparirà la seguente schermata. Dovrai fornire le seguenti informazioni come mostrato nello screenshot per creare la nuova classe.

Visualizza tutti gli indici

Quando si desidera avere una panoramica di tutti gli indici creati nel database, fare clic sul pulsante tutti gli indici nell'interfaccia utente dello schema. Ciò fornirà un rapido accesso ad alcune informazioni sugli indici (nome, tipo, proprietà, ecc.) E potrai rilasciarli o ricostruirli da qui.

Modifica classe

Fai clic su qualsiasi classe nella sezione dello schema, otterrai il seguente screenshot.

Durante la modifica di una classe, puoi aggiungere una proprietà o aggiungere un nuovo indice.

Aggiungi una proprietà

Fare clic sul pulsante Nuova proprietà per aggiungere una proprietà. Otterrai il seguente screenshot.

È necessario fornire i seguenti dettagli come mostrato nello screenshot per aggiungere la proprietà.

Aggiungi un indice

Fare clic sul pulsante Nuovo indice. Otterrai il seguente screenshot. È necessario fornire i seguenti dettagli come mostrato nello screenshot per aggiungere un indice.

Editor grafico

Fare clic sulla sezione del grafico. Non solo puoi visualizzare i tuoi dati in uno stile grafico, ma puoi anche interagire con il grafico e modificarlo.

Per popolare l'area del grafico, digitare una query nell'editor di query o utilizzare la funzionalità Invia al grafico dall'interfaccia utente Sfoglia.

Aggiungi vertici

Per aggiungere un nuovo vertice nel database dei grafici e nell'area Graph Canvas, è necessario premere il pulsante Add Vertex. Questa operazione viene eseguita in due passaggi.

Nel primo passaggio, devi scegliere la classe per il nuovo Vertex e quindi fare clic su Avanti.

Nella seconda fase, devi inserire i valori di campo del nuovo vertice. È anche possibile aggiungere campi personalizzati poiché OrientDB supporta la modalità senza schema. Per rendere persistente il nuovo vertice, fare clic su "Salva modifiche" e il vertice verrà salvato nel database e aggiunto all'area di disegno.

Elimina vertici

Apri il menu circolare facendo clic sul vertice che desideri eliminare. Apri il sottomenu posizionando il mouse sulla voce di menu altro (...) e quindi fai clic sull'icona del cestino.

Rimuovi vertici dalla tela

Aprire il menu circolare, aprire il sottomenu posizionando il mouse sulla voce di menu altro (...) e quindi fare clic sull'icona della gomma.

Ispeziona vertici

Se vuoi dare una rapida occhiata alla proprietà Vertex, clicca sull'icona dell'occhio.

Sicurezza

Studio 2.0 include la nuova Gestione della sicurezza, dove puoi gestire utenti e ruoli in modo grafico.

Utenti

È possibile eseguire le seguenti azioni per gestire gli utenti del database:

  • Cerca utenti
  • Aggiungi utenti
  • Elimina utenti
  • Modifica utente: i ruoli possono essere modificati in linea, per nome, stato e password fare clic su Edit pulsante

Aggiungi utenti

Per aggiungere un nuovo utente, fare clic su Add User pulsante, completare le informazioni per il nuovo utente (nome, password, stato, ruoli) e quindi salvare per aggiungere il nuovo utente al database.

Ruoli

È possibile eseguire le seguenti azioni per gestire i ruoli del database:

  • Ruolo di ricerca
  • Aggiungi ruolo
  • Elimina ruolo
  • Modifica ruolo

Aggiungi ruolo

Per aggiungere un nuovo utente, fare clic su Add Role pulsante, completare le informazioni per il nuovo ruolo (nome, ruolo padre, modalità) e quindi salvare per aggiungere il nuovo ruolo al database.

Aggiungi regola a un ruolo

Per aggiungere una nuova regola di sicurezza per il ruolo selezionato, fare clic su Add Rulepulsante. Questo ti chiederà la stringa della risorsa che desideri proteggere. Quindi puoi configurare i permessi CRUD sulla risorsa appena creata.

Simile a RDBMS, OrientDB supporta JDBC. Per questo, prima dobbiamo configurare l'ambiente per la programmazione JDBC. Di seguito è riportata la procedura per creare una connessione tra l'applicazione e il database.

Innanzitutto, dobbiamo scaricare il driver JDBC. Visitare il seguente collegamentohttps://code.google.com/archive/p/orient/downloads per scaricare OrientDB-JDBC.

Di seguito sono riportati i cinque passaggi di base per ottenere la connettività OrientDB-jdbc.

  • Carica il driver JDBC
  • Crea connessione
  • Crea una dichiarazione
  • Esegui istruzione
  • Chiudere la connessione

Esempio

Prova il seguente esempio per comprendere la connettività OrientDB-JDBC. Consideriamo di avere una tabella dei dipendenti che contiene i seguenti campi e i suoi tipi.

Sr.No. Nome campo genere
1 Id Numero intero
2 Nome Corda
3 Stipendio Numero intero
4 Data di iscrizione Data

È possibile creare uno schema (tabella) eseguendo i seguenti comandi.

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

Dopo aver eseguito tutti i comandi, otterrai la tabella Employee con i seguenti campi, il nome del dipendente con i campi id, age e join_date.

Salva il codice seguente in OrientJdbcDemo.java file.

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(); 
   } 
}

Il seguente comando viene utilizzato per compilare il programma precedente.

$ javac –classpath:.:orientdb-jdbc-1.0-SNAPSHOT.jar OrientJdbcDemo.java $ java –classpath:.:orientdb-jdbc-1.0-SNAPSHOT.jar OrientJdbcDemo

Se il comando precedente viene eseguito correttamente, otterrai il seguente output.

Records Successfully Inserted

Il driver OrientDB per Python utilizza il protocollo binario. PyOrient è il nome del progetto git hub che aiuta a connettere OrientDB con Python. Funziona con OrientDB versione 1.7 e successive.

Il seguente comando viene utilizzato per installare PyOrient.

pip install pyorient

È possibile utilizzare il file di script denominato demo.py per eseguire le seguenti attività:

  • Creare un'istanza client significa creare una connessione.

  • Crea DB denominato DB_Demo.

  • Apri DB denominato DB_Demo.

  • Crea classe my_class.

  • Crea ID proprietà e nome.

  • Inserisci il record nella mia classe.

//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')")

Esegui lo script precedente utilizzando il seguente comando.

$ python demo.py