OrientDB - Guide rapide
OrientDB est un système de gestion de base de données NoSQL Open Source. NoSQL Databasefournit un mécanisme pour stocker et récupérer des données sans relation ou non relationnelles qui se réfèrent à des données autres que des données tabulaires telles que des données de document ou des données de graphique. Les bases de données NoSQL sont de plus en plus utilisées dans le Big Data et les applications Web en temps réel. Les systèmes NoSQL sont aussi parfois appelés "Not Only SQL" pour souligner qu'ils peuvent prendre en charge les langages de requête de type SQL.
OrientDB appartient également à la famille NoSQL. OrientDB est une base de données de graphes distribués de deuxième génération avec la flexibilité des documents dans un seul produit avec une licence open source Apache 2. Il y avait plusieurs bases de données NoSQL sur le marché avant OrientDB, l'une d'entre elles étant MongoDB.
MongoDB contre OrientDB
MongoDB et OrientDB contiennent de nombreuses fonctionnalités communes mais les moteurs sont fondamentalement différents. MongoDB est une pure base de données de documents et OrientDB est un document hybride avec un moteur graphique.
traits | MongoDB | OrientDB |
---|---|---|
Relationships | Utilise le RDBMS JOINS pour créer une relation entre les entités. Il a un coût d'exécution élevé et ne s'adapte pas lorsque l'échelle de la base de données augmente. | Intègre et connecte des documents comme une base de données relationnelle. Il utilise des liens directs et ultra-rapides provenant du monde de la base de données de graphes. |
Fetch Plan | Opérations JOIN coûteuses. | Renvoie facilement un graphique complet avec des documents interconnectés. |
Transactions | Ne prend pas en charge les transactions ACID, mais prend en charge les opérations atomiques. | Prend en charge les transactions ACID ainsi que les opérations atomiques. |
Query language | Possède son propre langage basé sur JSON. | Le langage de requête est construit sur SQL. |
Indexes | Utilise l'algorithme B-Tree pour tous les index. | Prend en charge trois algorithmes d'indexation différents afin que l'utilisateur puisse obtenir les meilleures performances. |
Storage engine | Utilise la technique de mappage de mémoire. | Utilise le nom du moteur de stockage LOCAL et PLOCAL. |
OrientDB est le premier SGBD NoSQL open source multi-modèles qui associe la puissance des graphiques et la flexibilité des documents dans une base de données opérationnelle évolutive et performante.
Le fichier d'installation d'OrientDB est disponible en deux éditions -
Community Edition - L'édition communautaire OrientDB est publiée par Apache sous licence 0.2 en open source
Enterprise Edition- L'édition d'entreprise d'OrientDB est publiée en tant que logiciel propriétaire, basé sur l'édition communautaire. Il sert de prolongement de l'édition communautaire.
Ce chapitre explique la procédure d'installation de l'édition communautaire OrientDB car il est open source.
Conditions préalables
Les éditions Community et Enterprise peuvent s'exécuter sur n'importe quel système d'exploitation qui implémente la machine virtuelle Java (JVM). OrientDB nécessite Java avec la version 1.7 ou ultérieure.
Suivez les étapes suivantes pour télécharger et installer OrientDB sur votre système.
Étape 1 - Téléchargez le fichier de configuration binaire OrientDB
OrientDB est livré avec un fichier de configuration intégré pour installer la base de données sur votre système. Il fournit différents packages binaires précompilés (packages tarés ou compressés) pour différents systèmes d'exploitation. Vous pouvez télécharger les fichiers OrientDB à partir du lien Télécharger OrientDB .
La capture d'écran suivante montre la page de téléchargement d'OrientDB. Vous pouvez télécharger le fichier compressé ou taré en cliquant sur l'icône du système d'exploitation approprié.
Lors du téléchargement, vous obtiendrez le package binaire dans votre Downloads dossier.
Étape 2 - Extraire et installer OrientDB
Voici la procédure pour extraire et installer OrientDB pour différents systèmes d'exploitation.
Sous Linux
Après le téléchargement, vous obtiendrez orientdb-community-2.1.9.tar.gz fichier dans votre Downloadsdossier. Vous pouvez utiliser la commande suivante pour extraire le fichier taré.
$ tar –zxvf orientdb-community-2.1.9.tar.gz
Vous pouvez utiliser la commande suivante pour déplacer tous les fichiers de bibliothèque OrientDB de orientdbcommunity-2.1.9 to /opt/orientdb/annuaire. Ici, nous utilisons la commande super utilisateur (sudo), vous devez donc fournir un mot de passe super utilisateur pour exécuter la commande suivante.
$ sudo mv orientdb-community-2.1.9 /opt/orientdb
Vous pouvez utiliser les commandes suivantes pour enregistrer le orientdb commande et le serveur Orient.
$ export ORIENTDB_HoME = /opt/orientdb $ export PATH = $PATH:$ORIENTDB_HOME/bin
Sous Windows
Après le téléchargement, vous obtiendrez orientdb-community-2.1.9.zip fichier dans votre Downloadsdossier. Extrayez le fichier zip à l'aide de l'extracteur zip.
Déplacez le dossier extrait dans le C:\ annuaire.
Créez deux variables d'environnement ORIENTDB_HOME et PATH avec les valeurs données suivantes.
ORIENT_HOME = C:\orientdb-community-2.1.9
PATH = C:\orientdb-community-2.1.9\bin
Étape 3 - Configuration du serveur OrientDB en tant que service
En suivant les étapes ci-dessus, vous pouvez utiliser la version de bureau d'OrientDB. Vous pouvez démarrer le serveur de base de données OrientDB en tant que service en procédant comme suit. La procédure est différente selon votre système d'exploitation.
Sous Linux
OrientDB fournit un fichier de script nommé orientdb.shpour exécuter la base de données en tant que démon. Vous pouvez le trouver dans le répertoire bin / de votre répertoire d'installation OrientDB qui est $ ORIENTDB_HOME / bin / orientdb.sh.
Avant d'exécuter le fichier de script, vous devez modifier orientdb.shfichier pour définir deux variables. L'un estORIENTDB_DIR qui définit le chemin vers le répertoire d'installation (/opt/orientdb) et le second est ORIENTDB_USER qui définit le nom d'utilisateur pour lequel vous souhaitez exécuter OrientDB comme suit.
ORIENTDB_DIR = "/opt/orientdb"
ORIENTDB_USER = "<username you want to run OrientDB>"
Utilisez la commande suivante pour copier orientdb.sh déposer dans /etc/init.d/répertoire d'initialisation et d'exécution du script. Ici, nous utilisons la commande super utilisateur (sudo), vous devez donc fournir un mot de passe super utilisateur pour exécuter la commande suivante.
$ sudo cp $ORIENTDB_HOME/bin/orientdb.sh /etc/init.d/orientdb
Utilisez la commande suivante pour copier le fichier console.sh à partir du répertoire d'installation d'OrientDB $ORIENTDB_HOME/bin dans le répertoire bin système qui est /usr/bin pour accéder à la console d'Orient DB.
$ sudo cp $ ORIENTDB_HOME/bin/console.sh /usr/bin/orientdb
Utilisez la commande suivante pour démarrer le serveur de base de données ORIENTDB en tant que service. Ici, vous devez fournir le mot de passe de l'utilisateur respectif que vous mentionnez dans le fichier orientdb.sh pour démarrer le serveur.
$ service orientdb start
Utilisez la commande suivante pour savoir sur quel PID le démon du serveur OrientDB s'exécute.
$ service orientdb status
Utilisez la commande suivante pour arrêter le démon du serveur OrientDB. Ici, vous devez fournir le mot de passe de l'utilisateur respectif, que vous mentionnez dans le fichier orientdb.sh pour arrêter le serveur.
$ service orientdb stop
Sous Windows
OrientDB est une application serveur, elle doit donc effectuer plusieurs tâches avant de commencer à arrêter le processus de la machine virtuelle Java. Si vous souhaitez arrêter manuellement le serveur OrientDB, vous devez exécutershutdown.batfichier. Mais les instances de serveur ne s'arrêtent pas correctement, lorsque le système s'arrête soudainement sans exécuter le script ci-dessus. Les programmes qui sont contrôlés par le système d'exploitation avec un ensemble de signaux spécifiés sont appelésservices sous Windows.
Nous devons utiliser Apache Common Daemonqui permettent aux utilisateurs Windows d'encapsuler des applications Java en tant que service Windows. Voici la procédure pour télécharger et enregistrer le démon commun Apache.
Cliquez sur le lien suivant pour Apache Common Daemons pour Windows .
Cliquer sur common-daemon-1.0.15-bin-windows Télécharger.
Décompressez le common-daemon-1.0.15-bin-windowsannuaire. Après l'extraction, vous trouverezprunsrv.exe et prunmgr.exefichiers dans le répertoire. Dans ces -
prunsrv.exe file est une application de service pour exécuter des applications en tant que services.
prunmgr.exe file est une application utilisée pour surveiller et configurer les services Windows.
Allez dans le dossier d'installation d'OrientDB → créez un nouveau répertoire et nommez-le service.
Copiez le prunsrv.exe et prunmgr .exe collez-le dans le répertoire des services.
Pour configurer OrientDB en tant que service Windows, vous devez exécuter un court script qui utilise le prusrv.exe comme service Windows.
Avant de définir les services Windows, vous devez renommer prunsrv et prunmgr en fonction du nom du service. Pour par exemple OrientDBGraph et OrientDBGraphw respectivement. Ici, OrientDBGraph est le nom du service.
Copiez le script suivant dans le fichier nommé installService.bat et placez-le dans %ORIENTDB_HOME%\service\ annuaire.
:: 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
Le script nécessite deux paramètres -
L'emplacement de jvm.dll, par exemple C: \ ProgramFiles \ java \ jdk1.8.0_66 \ jre \ bin \ server \ jvm.dll
L'emplacement de l'installation d'OrientDB pour par exemple C: \ orientdb-community-2.1.9
Le service est installé lorsque vous exécutez le fichier OrientDBGraph.exe (Original prunsrv) et double-cliquez dessus.
Utilisez la commande suivante pour installer les services dans 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
Ouvrez les services du gestionnaire de tâches, vous trouverez la capture d'écran suivante avec le nom du service enregistré.
Étape 4 - Vérification de l'installation d'OrientDB
Cette étape vérifie l'installation du serveur de base de données OrientDB à l'aide des étapes suivantes.
- Exécutez le serveur.
- Exécutez la console.
- Dirigez le studio.
Ceci est unique selon le système d'exploitation.
Sous Linux
Suivez la procédure indiquée pour vérifier l'installation d'OrientDB sous Linux.
Running the server - Vous pouvez utiliser la commande suivante pour démarrer le serveur.
$ cd $ORIENTDB_HOME/bin $ ./server.sh
Vous pouvez également utiliser la commande suivante pour démarrer le serveur OrientDB en tant que démon UNIX.
$ service orientdb start
S'il est installé avec succès, vous recevrez la sortie suivante.
.
.` `
, `:.
`,` ,:`
.,. :,,
.,, ,,,
. .,.::::: ```` ::::::::: :::::::::
,` .::,,,,::.,,,,,,`;; .: :::::::::: ::: :::
`,. ::,,,,,,,:.,,.` ` .: ::: ::: ::: :::
,,:,:,,,,,,,,::. ` ` `` .: ::: ::: ::: :::
,,:.,,,,,,,,,: `::, ,, ::,::` : :,::` :::: ::: ::: ::: :::
,:,,,,,,,,,,::,: ,, :. : :: : .: ::: ::: :::::::
:,,,,,,,,,,:,:: ,, : : : : .: ::: ::: :::::::::
` :,,,,,,,,,,:,::, ,, .:::::::: : : .: ::: ::: ::: :::
`,...,,:,,,,,,,,,: .:,. ,, ,, : : .: ::: ::: ::: :::
.,,,,::,,,,,,,: `: , ,, : ` : : .: ::: ::: ::: :::
...,::,,,,::.. `: .,, :, : : : .: ::::::::::: ::: :::
,::::,,,. `: ,, ::::: : : .: ::::::::: ::::::::::
,,:` `,,.
,,, .,`
,,. `, 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 - Vous pouvez utiliser la commande suivante pour exécuter l'OrientDB sous la console.
$ orientdb
S'il est installé avec succès, vous recevrez la sortie suivante.
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 - Après avoir démarré le serveur, vous pouvez utiliser l'URL suivante (http://localhost:2480/) sur votre navigateur. Vous obtiendrez la capture d'écran suivante.
Sous Windows
Suivez la procédure indiquée pour vérifier l'installation d'OrientDB sous Windows.
Running the server - Vous pouvez utiliser la commande suivante pour démarrer le serveur.
> cd %ORIENTDB_HOME%\bin
> ./server.bat
S'il est installé avec succès, vous recevrez la sortie suivante.
.
.` `
, `:.
`,` ,:`
.,. :,,
.,, ,,,
. .,.::::: ```` ::::::::: :::::::::
,` .::,,,,::.,,,,,,`;; .: :::::::::: ::: :::
`,. ::,,,,,,,:.,,.` ` .: ::: ::: ::: :::
,,:,:,,,,,,,,::. ` ` `` .: ::: ::: ::: :::
,,:.,,,,,,,,,: `::, ,, ::,::` : :,::` :::: ::: ::: ::: :::
,:,,,,,,,,,,::,: ,, :. : :: : .: ::: ::: :::::::
:,,,,,,,,,,:,:: ,, : : : : .: ::: ::: :::::::::
` :,,,,,,,,,,:,::, ,, .:::::::: : : .: ::: ::: ::: :::
`,...,,:,,,,,,,,,: .:,. ,, ,, : : .: ::: ::: ::: :::
.,,,,::,,,,,,,: `: , ,, : ` : : .: ::: ::: ::: :::
...,::,,,,::.. `: .,, :, : : : .: ::::::::::: ::: :::
,::::,,,. `: ,, ::::: : : .: ::::::::: ::::::::::
,,:` `,,.
,,, .,`
,,. `, 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 - Vous pouvez utiliser la commande suivante pour exécuter OrientDB sous la console.
> %ORIENTDB_HOME%\bin\console.bat
S'il est installé avec succès, vous recevrez la sortie suivante.
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 - Après avoir démarré le serveur, vous pouvez utiliser l'URL suivante (http://localhost:2480/) sur votre navigateur. Vous obtiendrez la capture d'écran suivante.
La principale caractéristique d'OrientDB est de prendre en charge les objets multimodèles, c'est-à-dire qu'il prend en charge différents modèles tels que Document, Graphique, Clé / Valeur et Objet réel. Il contient une API distincte pour prendre en charge ces quatre modèles.
Modèle de document
Le modèle de document terminologique appartient à la base de données NoSQL. Cela signifie que les données sont stockées dans les documents et que le groupe de documents est appelé commeCollection. Techniquement, document signifie un ensemble de paires clé / valeur ou également appelé champs ou propriétés.
OrientDB utilise les concepts tels que les classes, les clusters et les liens pour stocker, regrouper et analyser les documents.
Le tableau suivant illustre la comparaison entre le modèle relationnel, le modèle de document et le modèle de document OrientDB -
Modèle relationnel | Modèle de document | Modèle de document OrientDB |
---|---|---|
Table | Collection | Classe ou cluster |
Rangée | Document | Document |
Colonne | Paire clé / valeur | Champ de document |
Relation | Indisponible | Lien |
Modèle de graphique
Une structure de données de graphique est un modèle de données qui peut stocker des données sous la forme de sommets (nœuds) interconnectés par des arêtes (arcs). L'idée de la base de données de graphes OrientDB est venue du graphe de propriétés. Le sommet et l'arête sont les principaux artefacts du modèle Graph. Ils contiennent les propriétés qui peuvent les faire ressembler à des documents.
Le tableau suivant montre une comparaison entre le modèle de graphique, le modèle de données relationnel et le modèle de graphique OrientDB.
Modèle relationnel | Modèle de graphique | Modèle de graphe OrientDB |
---|---|---|
Table | Classe Vertex et Edge | Classe qui étend "V" (pour Vertex) et "E" (pour Edges) |
Rangée | Sommet | Sommet |
Colonne | Propriété Vertex and Edge | Propriété Vertex and Edge |
Relation | Bord | Bord |
Le modèle clé / valeur
Le modèle clé / valeur signifie que les données peuvent être stockées sous la forme d'une paire clé / valeur où les valeurs peuvent être de types simples et complexes. Il peut prendre en charge des documents et des éléments graphiques en tant que valeurs.
Le tableau suivant illustre la comparaison entre le modèle relationnel, le modèle clé / valeur et le modèle clé / valeur OrientDB.
Modèle relationnel | Modèle clé / valeur | Modèle clé / valeur OrientDB |
---|---|---|
Table | Seau | Classe ou cluster |
Rangée | Paire clé / valeur | Document |
Colonne | Indisponible | Champ de document ou propriété Vertex / Edge |
Relation | Indisponible | Lien |
Le modèle objet
Ce modèle a été hérité par la programmation orientée objet et prend en charge Inheritance entre types (les sous-types étend les super-types), Polymorphism lorsque vous faites référence à une classe de base et Direct binding from / to Objets utilisés dans les langages de programmation.
Le tableau suivant illustre la comparaison entre le modèle relationnel, le modèle objet et le modèle objet OrientDB.
Modèle relationnel | Modèle d'objet | Modèle d'objet OrientDB |
---|---|---|
Table | Classe | Classe ou cluster |
Rangée | Objet | Document ou sommet |
Colonne | Propriété de l'objet | Champ de document ou propriété Vertex / Edge |
Relation | Aiguille | Lien |
Avant d'aller plus loin dans les détails, il est préférable de connaître la terminologie de base associée à OrientDB. Voici quelques-unes des terminologies importantes.
Record
La plus petite unité que vous pouvez charger et stocker dans la base de données. Les enregistrements peuvent être stockés dans quatre types.
- Document
- Octets d'enregistrement
- Vertex
- Edge
ID d'enregistrement
Lorsque OrientDB génère un enregistrement, le serveur de base de données attribue automatiquement un identifiant d'unité à l'enregistrement, appelé RecordID (RID). Le RID ressemble à # <cluster>: <position>. <cluster> signifie le numéro d'identification du cluster et la <position> signifie la position absolue de l'enregistrement dans le cluster.
Des documents
Le document est le type d'enregistrement le plus flexible disponible dans OrientDB. Les documents sont typés doucement et sont définis par des classes de schéma avec une contrainte définie, mais vous pouvez également insérer le document sans aucun schéma, c'est-à-dire qu'il prend également en charge le mode sans schéma.
Les documents peuvent être facilement traités par exportation et importation au format JSON. Par exemple, jetez un œil à l'exemple de document JSON suivant. Il définit les détails du document.
{
"id" : "1201",
"name" : "Jay",
"job" : "Developer",
"creations" : [
{
"name" : "Amiga",
"company" : "Commodore Inc."
},
{
"name" : "Amiga 500",
"company" : "Commodore Inc."
}
]
}
RecordBytes
Le type d'enregistrement est le même que le type BLOB dans le SGBDR. OrientDB peut charger et stocker le type d'enregistrement de document avec des données binaires.
Sommet
La base de données OrientDB n'est pas seulement une base de données Document, mais également une base de données Graph. Les nouveaux concepts tels que Vertex et Edge sont utilisés pour stocker les données sous forme de graphique. Dans les bases de données de graphes, l'unité de données la plus élémentaire est le nœud, qui dans OrientDB est appelé un sommet. Le sommet stocke les informations de la base de données.
Bord
Il existe un type d'enregistrement distinct appelé Edge qui connecte un sommet à un autre. Les arêtes sont bidirectionnelles et ne peuvent relier que deux sommets. Il existe deux types d'arêtes dans OrientDB, l'un est régulier et l'autre léger.
Classe
La classe est un type de modèle de données et le concept tiré du paradigme de programmation orientée objet. Sur la base du modèle de base de données documentaire traditionnel, les données sont stockées sous forme de collection, tandis que dans le modèle de base de données relationnelle, les données sont stockées dans des tables. OrientDB suit l'API Document avec le paradigme OPPS. En tant que concept, la classe dans OrientDB a la relation la plus proche avec la table dans les bases de données relationnelles, mais (contrairement aux tables) les classes peuvent être sans schéma, pleines de schéma ou mixtes. Les classes peuvent hériter d'autres classes, créant des arbres de classes. Chaque classe a son ou ses propres clusters (créés par défaut, si aucun n'est défini).
Grappe
Le cluster est un concept important utilisé pour stocker des enregistrements, des documents ou des sommets. En termes simples, Cluster est un endroit où un groupe d'enregistrements est stocké. Par défaut, OrientDB créera un cluster par classe. Tous les enregistrements d'une classe sont stockés dans le même cluster ayant le même nom que la classe. Vous pouvez créer jusqu'à 32 767 clusters (2 ^ 15-1) dans une base de données.
La classe CREATE est une commande utilisée pour créer un cluster avec un nom spécifique. Une fois le cluster créé, vous pouvez utiliser le cluster pour enregistrer des enregistrements en spécifiant le nom lors de la création de tout modèle de données.
Des relations
OrientDB prend en charge deux types de relations: référencées et intégrées. Referenced relationships signifie qu'il stocke un lien direct vers les objets cibles des relations. Embedded relationshipssignifie qu'il stocke la relation dans l'enregistrement qui l'intègre. Cette relation est plus forte que la relation de référence.
Base de données
La base de données est une interface pour accéder au stockage réel. Le service informatique comprend des concepts de haut niveau tels que les requêtes, les schémas, les métadonnées, les index, etc. OrientDB fournit également plusieurs types de bases de données. Pour plus d'informations sur ces types, consultez Types de base de données.
OrientDB prend en charge plusieurs types de données de manière native. Voici le tableau complet sur le même.
Sr. No. | Type | La description |
---|---|---|
1 | Booléen | Gère uniquement les valeurs True ou False. Java types: java.lang.Boolean Min: 0 Max: 1 |
2 | Entier | Entiers signés 32 bits. Java types: java.lang.Interger Min: -2 147 483 648 Max: +2 147 483 647 |
3 | Court | Petits entiers signés 16 bits. Java types: java.lang.short Min: -32 768 Max: 32 767 |
4 | Longue | Grands entiers signés 64 bits. Java types: java.lang.Long Min: -2 63 Max: +2 63 -1 |
5 | Flotte | Nombres décimaux. Java types: java.lang.Float : 2 -149 Max: ( 2-2-23 ) * 2, 127 |
6 | Double | Nombres décimaux de haute précision. Java types: Java.lang.Double. Min: 2 à 1074 Max: (2-2 -52 ) * 2 1023 |
sept | Date-heure | N'importe quelle date avec une précision allant jusqu'à millisecondes. Java types: java.util.Date |
8 | Chaîne | Toute chaîne sous forme de séquence alphanumérique de caractères. Java types: java.lang.String |
9 | Binaire | Peut contenir n'importe quelle valeur sous forme de tableau d'octets. Java types: octet [] Min: 0 Max: 2 147 483 647 |
dix | Embarqué | L'enregistrement est contenu dans le propriétaire. L'enregistrement contenu n'a pas RecordId. Java types: ORecord |
11 | Liste intégrée | Les enregistrements sont contenus dans le propriétaire. Les enregistrements contenus n'ont aucun RecordIds et sont accessibles uniquement en parcourant l'enregistrement du propriétaire. Java types: Liste <objets> Min: 0 Max: 41 000 000 éléments |
12 | Ensemble intégré | Les enregistrements sont contenus dans le propriétaire. Les enregistrements contenus n'ont pas RecordId et sont accessibles uniquement en parcourant l'enregistrement du propriétaire. Java types: définir <objets> Min: 0 Max: 41 000 000 éléments |
13 | Carte intégrée | Les enregistrements sont contenus dans le propriétaire en tant que valeurs des entrées, tandis que les clés ne peuvent être que des chaînes. Les enregistrements contenus n'ont pas RecordId et ne sont accessibles qu'en naviguant dans l'enregistrement propriétaire. Java types: Carte <Chaîne, ORecord> Min: 0 Max: 41 000 000 éléments |
14 | Lien | Lien vers un autre enregistrement. C'est une relation individuelle commune Java Types: ORID, <? étend ORecord> Min: 1 Max: 32767: 2 ^ 63-1 |
15 | Liste de liens | Liens vers d'autres documents. Il s'agit d'une relation un-à-plusieurs courante dans laquelle seuls les RecordIds sont stockés. Java types: Liste <? Prolonge ORecord> Min: 0 Max: 41 000 000 éléments |
16 | Ensemble de liens | Liens vers d'autres enregistrements. C'est une relation un-à-plusieurs commune. Java types: Réglez <? étend ORecord> Min: 0 Max: 41 000 000 éléments |
17 | Lien carte | Liens vers d'autres enregistrements en tant que valeur des entrées, tandis que les clés ne peuvent être que des chaînes. C'est une relation un-à-plusieurs commune. Seuls les RecordIds sont stockés. Java types: Carte <Chaîne,? étend l'enregistrement> Min: 0 Max: 41 000 000 éléments |
18 | Octet | Un octet. Utile pour stocker de petits entiers signés 8 bits. Java types: java.lang.Byte Min: -128 Max: +127 |
19 | Transitoire | Toute valeur non stockée dans la base de données. |
20 | Date | N'importe quelle date comme année, mois et jour. Java Types: java.util.Date |
21 | Douane | Utilisé pour stocker un type personnalisé fournissant les méthodes Marshall et Unmarshall. Java types: OSerializableStream Min: 0 Max: X |
22 | Décimal | Nombres décimaux sans arrondi. Java types: java.math.BigDecimal |
23 | LinkBag | Liste des RecordIds en tant que RidBag spécifique. Java types: ORidBag |
24 | Tout | Type non déterminé, utilisé pour spécifier des collections de type mixte et null. |
Dans les chapitres suivants, l'utilisation de ces types de données dans OrientDB est abordée.
La console OrientDB est une application Java conçue pour fonctionner avec les bases de données OrientDB et les instances de serveur. Il existe plusieurs modes de console pris en charge par OrientDB.
Mode interactif
C'est le mode par défaut. Lancez simplement la console en exécutant le script suivantbin/console.sh (ou bin/console.batdans les systèmes MS Windows). Assurez-vous d'avoir l'autorisation d'exécution dessus.
OrientDB console v.1.6.6 www.orientechnologies.com
Type 'help' to display all the commands supported.
orientdb>
Une fois terminé, la console est prête à accepter les commandes.
Temps différé
Pour exécuter des commandes en mode batch, exécutez ce qui suit bin/console.sh (ou bin/console.bat dans les systèmes MS Windows) en passant toutes les commandes séparées par un point-virgule ";".
orientdb> console.bat "connect remote:localhost/demo;select * from profile"
Ou appelez le script de la console en passant le nom du fichier au format texte contenant la liste des commandes à exécuter. Les commandes doivent être séparées par un point-virgule ";".
Exemple
Command.txt contient la liste des commandes que vous souhaitez exécuter via la console OrientDB. La commande suivante accepte le lot de commandes du fichier command.txt.
orientdb> console.bat commands.txt
En mode batch, vous pouvez ignorer les erreurs pour laisser le script continuer l'exécution en définissant la variable "ignoreErrors" sur true.
orientdb> set ignoreErrors true
Activer l'écho
Lorsque vous exécutez des commandes de console dans le pipeline, vous devrez les afficher. Activez "l'écho" des commandes en le définissant comme propriété au début. Voici la syntaxe pour activer la propriété echo dans la console OrientDB.
orientdb> set echo true
La référence SQL de la base de données OrientDB fournit plusieurs commandes pour créer, modifier et supprimer des bases de données.
L'instruction suivante est une syntaxe de base de la commande Create Database.
CREATE DATABASE <database-url> [<user> <password> <storage-type> [<db-type>]]
Voici les détails des options de la syntaxe ci-dessus.
<database-url>- Définit l'URL de la base de données. L'URL contient deux parties, l'une est <mode> et la seconde est <chemin>.
<mode> - Définit le mode, c'est-à-dire le mode local ou le mode distant.
<path> - Définit le chemin d'accès à la base de données.
<user> - Définit l'utilisateur que vous souhaitez connecter à la base de données.
<password> - Définit le mot de passe pour se connecter à la base de données.
<storage-type>- Définit les types de stockage. Vous pouvez choisir entre PLOCAL et MEMORY.
Exemple
Vous pouvez utiliser la commande suivante pour créer une base de données locale nommée demo.
Orientdb> CREATE DATABASE PLOCAL:/opt/orientdb/databses/demo
Si la base de données est créée avec succès, vous obtiendrez la sortie suivante.
Database created successfully.
Current database is: plocal: /opt/orientdb/databases/demo
orientdb {db = demo}>
La base de données est l'un des modèles de données importants avec différents attributs que vous pouvez modifier selon vos besoins.
L'instruction suivante est la syntaxe de base de la commande Alter Database.
ALTER DATABASE <attribute-name> <attribute-value>
Où <attribute-name> définit l'attribut que vous souhaitez modifier et <attributevalue> définit la valeur que vous souhaitez définir pour cet attribut.
Le tableau suivant définit la liste des attributs pris en charge pour modifier une base de données.
Sr.No. | Nom d'attribut | La description |
---|---|---|
1 | STATUT | Définit l'état de la base de données entre différents attributs. |
2 | IMPORTATION | Définit le statut d'importation. |
3 | DEFAULTCLUSTERID | Définit le cluster par défaut à l'aide de l'ID. Par défaut, c'est 2. |
4 | FORMAT DE DATE | Définit le format de date particulier par défaut. Par défaut, il s'agit de "aaaa-MM-jj". |
5 | DATETIMEFORMAT | Définit le format de date et d'heure par défaut. Par défaut, il s'agit de "aaaa-MM-jj HH: mm: ss". |
6 | FUSEAU HORAIRE | Définit le fuseau horaire particulier. Par défaut, il s'agit du fuseau horaire par défaut de la machine virtuelle Java (JVM). |
sept | PAYS LOCAL | Définit le pays des paramètres régionaux par défaut. Par défaut, il s'agit du pays de paramètres régionaux par défaut de JVM. Par exemple: "GB". |
8 | LANGUE LOCALE | Définit la langue locale par défaut. Par défaut, il s'agit de la langue locale par défaut de JVM. Par exemple: "en". |
9 | CHARSET | Définit le type de jeu de caractères. Par défaut, il s'agit du jeu de caractères par défaut de JVM. Par exemple: "utf8". |
dix | CLUSTERSELECTION | Définit la stratégie par défaut utilisée pour sélectionner le cluster. Ces stratégies sont créées avec la création de la classe. Les stratégies prises en charge sont par défaut, roundrobin et équilibrées. |
11 | MINIMUMCLUSTERS | Définit le nombre minimum de clusters à créer automatiquement lorsqu'une nouvelle classe est créée. Par défaut, il est 1. |
12 | DOUANE | Définit la propriété personnalisée. |
13 | VALIDATION | Désactive ou active les validations pour toute la base de données. |
Exemple
A partir de la version d'OrientDB-2.2, le nouvel analyseur SQL est ajouté qui ne permettra pas la syntaxe régulière dans certains cas. Par conséquent, nous devons désactiver le nouvel analyseur SQL (StrictSQL) dans certains cas. Vous pouvez utiliser la commande Alter database suivante pour désactiver l'analyseur StrictSQL.
orientdb> ALTER DATABASE custom strictSQL = false
Si la commande est exécutée avec succès, vous obtiendrez la sortie suivante.
Database updated successfully
Comme le SGBDR, OrientDB prend également en charge les opérations de sauvegarde et de restauration. Lors de l'exécution de l'opération de sauvegarde, tous les fichiers de la base de données actuelle seront convertis au format zip compressé en utilisant l'algorithme ZIP. Cette fonctionnalité (Sauvegarde) peut être utilisée automatiquement en activant le plugin de serveur de sauvegarde automatique.
La sauvegarde d'une base de données ou l'exportation d'une base de données est la même chose, cependant, en fonction de la procédure, nous devons savoir quand utiliser la sauvegarde et quand utiliser l'exportation.
Lors de la sauvegarde, il créera une copie cohérente d'une base de données, toutes les autres opérations d'écriture sont verrouillées et attendent la fin du processus de sauvegarde. Dans cette opération, il créera un fichier de sauvegarde en lecture seule.
Si vous avez besoin de l'opération de lecture et d'écriture simultanée tout en effectuant une sauvegarde, vous devez choisir d'exporter une base de données au lieu de sauvegarder une base de données. L'exportation ne verrouille pas la base de données et autorise les écritures simultanées pendant le processus d'exportation.
L'instruction suivante est la syntaxe de base de la sauvegarde de la base de données.
./backup.sh <dburl> <user> <password> <destination> [<type>]
Voici les détails des options de la syntaxe ci-dessus.
<dburl> - L'URL de la base de données où se trouve la base de données soit dans l'emplacement local, soit dans l'emplacement distant.
<user> - Spécifie le nom d'utilisateur pour exécuter la sauvegarde.
<password> - Fournit le mot de passe de l'utilisateur particulier.
<destination> - Emplacement du fichier de destination indiquant où stocker le fichier zip de sauvegarde.
<type>- Type de sauvegarde facultatif. Il a l'une des deux options.
Par défaut - verrouille la base de données pendant la sauvegarde.
LVM - utilise un instantané de copie sur écriture LVM en arrière-plan.
Exemple
Effectuez une sauvegarde de la démo de la base de données qui se trouve dans le système de fichiers local / opt / orientdb / databases / demo dans un fichier nommé sample-demo.zip et situé dans le répertoire courant.
Vous pouvez utiliser la commande suivante pour effectuer une sauvegarde de la démo de la base de données.
$ backup.sh plocal: opt/orientdb/database/demo admin admin ./backup-demo.zip
Utilisation de la console
La même chose que vous pouvez faire en utilisant la console OrientDB. Avant d'effectuer la sauvegarde d'une base de données particulière, vous devez d'abord vous connecter à la base de données. Vous pouvez utiliser la commande suivante pour vous connecter à la base de données nommée demo.
orientdb> CONNECT PLOCAL:/opt/orientdb/databases/demo admin admin
Après vous être connecté, vous pouvez utiliser la commande suivante pour effectuer une sauvegarde de la base de données dans un fichier nommé «backup-demo.zip» dans le répertoire actuel.
orientdb {db=demo}> BACKUP DATABASE ./backup-demo.zip
Si cette commande est exécutée avec succès, vous recevrez des notifications de succès avec le message suivant.
Backup executed in 0.30 seconds
Comme comme SGBDR, OrientDB prend également en charge l'opération de restauration. Uniquement à partir du mode console, vous pouvez exécuter cette opération avec succès.
L'instruction suivante est la syntaxe de base pour l'opération de restauration.
orientdb> RESTORE DATABSE <url of the backup zip file>
Exemple
Vous devez effectuer cette opération uniquement à partir du mode console. Par conséquent, vous devez d'abord démarrer la console OrientDB à l'aide de la commande OrientDB suivante.
$ orientdb
Ensuite, connectez-vous à la base de données respective pour restaurer la sauvegarde. Vous pouvez utiliser la commande suivante pour vous connecter à la base de données nommée demo.
orientdb> CONNECT PLOCAL:/opt/orientdb/databases/demo admin admin
Une fois la connexion établie, vous pouvez utiliser la commande suivante pour restaurer la sauvegarde à partir du fichier «backup-demo.zip». Avant de l'exécuter, assurez-vous que le fichier backup-demo.zip est placé dans le répertoire courant.
Orientdb {db = demo}> RESTORE DATABASE backup-demo.zip
Si cette commande est exécutée avec succès, vous recevrez des notifications de réussite avec le message suivant.
Database restored in 0.26 seconds
Ce chapitre explique comment se connecter à une base de données particulière à partir de la ligne de commande OrientDB. Il ouvre une base de données.
L'instruction suivante est la syntaxe de base de la commande Connect.
CONNECT <database-url> <user> <password>
Voici les détails des options de la syntaxe ci-dessus.
<database-url>- Définit l'URL de la base de données. L'URL contient deux parties, l'une est <mode> et la seconde est <chemin>.
<mode> - Définit le mode, c'est-à-dire le mode local ou le mode distant.
<path> - Définit le chemin d'accès à la base de données.
<user> - Définit l'utilisateur que vous souhaitez connecter à la base de données.
<password> - Définit le mot de passe pour se connecter à la base de données.
Exemple
Nous avons déjà créé une base de données nommée «démo» dans les chapitres précédents. Dans cet exemple, nous nous connecterons à celui-ci à l'aide de l'utilisateur admin.
Vous pouvez utiliser la commande suivante pour vous connecter à la base de données de démonstration.
orientdb> CONNECT PLOCAL:/opt/orientdb/databases/demo admin admin
S'il est correctement connecté, vous obtiendrez la sortie suivante -
Connecting to database [plocal:/opt/orientdb/databases/demo] with user 'admin'…OK
Orientdb {db = demo}>
Ce chapitre explique comment se déconnecter d'une base de données particulière à partir de la ligne de commande OrientDB. Il ferme la base de données actuellement ouverte.
L'instruction suivante est la syntaxe de base de la commande Disconnect.
DISCONNECT
Note - Vous ne pouvez utiliser cette commande qu'après vous être connecté à une base de données particulière et elle ne fermera que la base de données en cours d'exécution.
Exemple
Dans cet exemple, nous utiliserons la même base de données nommée «demo» que nous avons créée dans le chapitre précédent. Nous allons nous déconnecter de la base de données de démonstration.
Vous pouvez utiliser la commande suivante pour déconnecter la base de données.
orientdb {db = demo}> DISCONNECT
S'il est déconnecté avec succès, vous obtiendrez la sortie suivante -
Disconnecting to database [plocal:/opt/orientdb/databases/demo] with user 'admin'…OK
orientdb>
Ce chapitre explique comment obtenir des informations sur une base de données particulière à partir de la ligne de commande OrientDB.
L'instruction suivante est la syntaxe de base de la commande Info.
info
Note - Vous ne pouvez utiliser cette commande qu'après vous être connecté à une base de données particulière et elle récupérera uniquement les informations de la base de données en cours d'exécution.
Exemple
Dans cet exemple, nous utiliserons la même base de données nommée «demo» que nous avons créée dans le chapitre précédent. Nous récupérerons les informations de base de la base de données de démonstration.
Vous pouvez utiliser la commande suivante pour déconnecter la base de données.
orientdb {db = demo}> info
S'il est déconnecté avec succès, vous obtiendrez la sortie suivante.
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 |
---------------------------------+-------+-------------------+----------------+
Ce chapitre explique comment obtenir la liste de toutes les bases de données d'une instance à partir de la ligne de commande OrientDB.
L'instruction suivante est la syntaxe de base de la commande info.
LIST DATABASES
Note - Vous ne pouvez utiliser cette commande qu'après vous être connecté à un serveur local ou distant.
Exemple
Avant de récupérer la liste des bases de données, nous devons nous connecter au serveur localhost via le serveur distant. Il est nécessaire de rappeler que le nom d'utilisateur et le mot de passe pour se connecter à l'instance localhost sont respectivement guest et guest, qui sont configurés dans leorintdb/config/orientdb-server-config.xml fichier.
Vous pouvez utiliser la commande suivante pour vous connecter à l'instance de serveur de base de données localhost.
orientdb> connect remote:localhost guest
Il demandera le mot de passe. Selon le mot de passe du fichier de configuration pour l'invité est également invité. S'il est correctement connecté, vous obtiendrez la sortie suivante.
Connecting to remote Server instance [remote:localhost] with user 'guest'...OK
orientdb {server = remote:localhost/}>
Après vous être connecté au serveur de base de données localhost, vous pouvez utiliser la commande suivante pour répertorier les bases de données.
orientdb {server = remote:localhost/}> list databases
S'il est exécuté avec succès, vous obtiendrez la sortie suivante -
Found 6 databases:
* demo (plocal)
* s2 (plocal)
* s1 (plocal)
* GratefulDeadConcerts (plocal)
* s3 (plocal)
* sample (plocal)
orientdb {server = remote:localhost/}>
Chaque fois que vous souhaitez rendre l'état de la base de données statique, cela signifie un état dans lequel la base de données n'a répondu à aucune des opérations de lecture et d'écriture. Simplement dit, la base de données est en état de gel.
Dans ce chapitre, vous pouvez apprendre à geler la base de données à partir de la ligne de commande OrientDB.
L'instruction suivante est la syntaxe de base de la commande freeze database.
FREEZE DATABASE
Note - Vous ne pouvez utiliser cette commande qu'après vous être connecté à une base de données particulière dans une base de données distante ou locale.
Exemple
Dans cet exemple, nous utiliserons la même base de données nommée «demo» que nous avons créée dans le chapitre précédent. Nous allons geler cette base de données à partir de la CLI.
Vous pouvez utiliser la commande suivante pour geler la base de données.
Orientdb {db = demo}> FREEZE DATABASE
S'il est exécuté avec succès, vous obtiendrez la sortie suivante.
Database 'demo' was frozen successfully
Dans ce chapitre, vous pouvez apprendre comment libérer la base de données de l'état de gel via la ligne de commande OrientDB.
L'instruction suivante est la syntaxe de base de la commande Release database.
RELEASE DATABASE
Note - Vous ne pouvez utiliser cette commande qu'après vous être connecté à une base de données particulière, qui est en état de gel.
Exemple
Dans cet exemple, nous utiliserons la même base de données nommée «demo» que nous avons créée dans le chapitre précédent. Nous publierons la base de données gelée dans le chapitre précédent.
Vous pouvez utiliser la commande suivante pour libérer la base de données.
Orientdb {db = demo}> RELEASE DATABASE
S'il est exécuté avec succès, vous obtiendrez la sortie suivante.
Database 'demo' was release successfully
Dans ce chapitre, vous pouvez apprendre à afficher la configuration d'une base de données particulière via la ligne de commande OrientDB. Cette commande s'applique aux bases de données locales et distantes.
Les informations de configuration contiennent le cache par défaut activé ou non, la taille de ce cache, la valeur du facteur de charge, la mémoire maximale pour la carte, la taille de la page de nœud, la taille minimale et maximale du pool, etc.
L'instruction suivante est la syntaxe de base de la commande config database.
CONFIG
Note - Vous ne pouvez utiliser cette commande qu'après vous être connecté à une base de données particulière.
Exemple
Dans cet exemple, nous utiliserons la même base de données nommée «demo» que nous avons créée dans le chapitre précédent.
Vous pouvez utiliser la commande suivante pour afficher la configuration de la base de données de démonstration.
Orientdb {db = demo}> CONFIG
S'il est exécuté avec succès, vous obtiendrez la sortie suivante.
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}>
Dans la liste des paramètres de configuration ci-dessus, si vous souhaitez modifier l'une des valeurs de paramètre, vous pouvez le faire facilement à partir de la ligne de commande en utilisant config set et get command.
Ensemble de configuration
Vous pouvez mettre à jour la valeur de la variable de configuration en utilisant le CONFIG SET commander.
L'instruction suivante est la syntaxe de base de la commande config set.
CONFIG SET <config-variable> <config-value>
Note - Vous ne pouvez utiliser cette commande qu'après vous être connecté à une base de données particulière.
Exemple
Dans cet exemple, nous utiliserons la même base de données nommée «demo» que nous avons créée dans le chapitre précédent. Nous allons modifier la valeur de la variable 'tx.autoRetry' à 5.
Vous pouvez utiliser la commande suivante pour définir la configuration de la base de données de démonstration.
orientdb {db = demo}> CONFIG SET tx.autoRetry 5
S'il est exécuté avec succès, vous obtiendrez la sortie suivante.
Local configuration value changed correctly
Config Get
Vous pouvez afficher la valeur de la variable de configuration en utilisant le CONFIG GET commander.
L'instruction suivante est la syntaxe de base de la commande config get.
CONFIG GET <config-variable>
Note - Vous ne pouvez utiliser cette commande qu'après vous être connecté à une base de données particulière.
Exemple
Dans cet exemple, nous utiliserons la même base de données nommée «demo» que nous avons créée dans le chapitre précédent. Nous allons essayer de récupérer la valeur de la variable 'tx.autoRetry'.
Vous pouvez utiliser la commande suivante pour afficher la configuration de la base de données de démonstration.
orientdb {db = demo}> CONFIG GET tx.autoRetry
S'il est exécuté avec succès, vous obtiendrez la sortie suivante.
Local configuration: tx.autoRetry = 5
Comme le SGBDR, OrientDB fournit également des fonctionnalités telles que l'exportation et l'importation de la base de données. OrientDB utilise le format JSON pour exporter les données. Par défaut, la commande d'exportation utilise l'algorithme GZIP pour compresser les fichiers.
Lors de l'exportation d'une base de données, cela ne verrouille pas la base de données, ce qui signifie que vous pouvez effectuer des opérations de lecture et d'écriture simultanées sur celle-ci. Cela signifie également que vous pouvez créer une copie exacte de ces données grâce à des opérations de lecture et d'écriture simultanées.
Dans ce chapitre, vous pouvez apprendre à exporter la base de données à partir de la ligne de commande OrientDB.
L'instruction suivante est la syntaxe de base de la commande Exporter la base de données.
EXPORT DATABASE <output file>
Note - Vous ne pouvez utiliser cette commande qu'après vous être connecté à une base de données particulière.
Exemple
Dans cet exemple, nous utiliserons la même base de données nommée «demo» que nous avons créée dans le chapitre précédent. Vous pouvez utiliser la commande suivante pour exporter la base de données vers un fichier nommé 'export-demo'.
orientdb {db = demo}> EXPORT DATABASE ./export-demo.export
S'il est exécuté avec succès, il créera un fichier nommé 'export-demo.zip' ou 'exportdemo.gz' basé sur le système d'exploitation et vous obtiendrez la sortie suivante.
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
Chaque fois que vous souhaitez importer la base de données, vous devez utiliser le fichier exporté au format JSON, qui est généré par la commande d'exportation.
Dans ce chapitre, vous pouvez apprendre à importer la base de données à partir de la ligne de commande OrientDB.
L'instruction suivante est la syntaxe de base de la commande Import database.
IMPORT DATABASE <input file>
Note - Vous ne pouvez utiliser cette commande qu'après vous être connecté à une base de données particulière.
Exemple
Dans cet exemple, nous utiliserons la même base de données nommée «demo» que nous avons créée dans le chapitre précédent. Vous pouvez utiliser la commande suivante pour importer la base de données dans un fichier nommé «export-demo.gz».
orientdb {db = demo}> IMPORT DATABASE ./export-demo.export.gz
S'il est exécuté avec succès, vous obtiendrez la sortie suivante avec la notification réussie.
Database import completed in 11612ms
Semblable au SGBDR, OrientDB fournit également des concepts de transaction tels que Commit et Rollback. Commit fait référence à la clôture de la transaction en enregistrant toutes les modifications dans la base de données. Rollback fait référence à la récupération de l'état de la base de données au point où vous avez ouvert la transaction.
L'instruction suivante est la syntaxe de base de la commande Commit database.
COMMIT
Note - Vous ne pouvez utiliser cette commande qu'après vous être connecté à une base de données particulière et après avoir commencé la transaction.
Exemple
Dans cet exemple, nous utiliserons la même base de données nommée «demo» que nous avons créée dans le chapitre précédent. Nous verrons le fonctionnement de la transaction de validation et stockerons un enregistrement à l'aide de transactions.
Commencez par lancer la transaction en utilisant les éléments suivants BEGIN commander.
orientdb {db = demo}> BEGIN
Ensuite, insérez un enregistrement dans une table d'employés avec les valeurs id = 12 et name = satish.P à l'aide de la commande suivante.
orientdb> INSERT INTO employee (id, name) VALUES (12, 'satish.P')
Vous pouvez utiliser la commande suivante pour valider la transaction.
orientdb> commit
Si cette transaction est validée avec succès, vous obtiendrez la sortie suivante.
Transaction 2 has been committed in 4ms
Dans ce chapitre, vous apprendrez comment annuler la transaction non validée via l'interface de ligne de commande OrientDB.
L'instruction suivante est la syntaxe de base de la commande de base de données Rollback.
ROLLBACK
Note - Vous ne pouvez utiliser cette commande qu'après vous être connecté à une base de données particulière et après avoir commencé la transaction.
Exemple
Dans cet exemple, nous utiliserons la même base de données nommée «demo» que nous avons créée dans le chapitre précédent. Nous verrons l'opération de la transaction d'annulation et stockerons un enregistrement à l'aide de transactions.
Commencez par lancer la transaction en utilisant les éléments suivants BEGIN commander.
orientdb {db = demo}> BEGIN
Ensuite, insérez un enregistrement dans une table d'employés avec les valeurs id = 12 et name = satish.P à l'aide de la commande suivante.
orientdb> INSERT INTO employee (id, name) VALUES (12, 'satish.P')
Vous pouvez utiliser la commande suivante pour récupérer les enregistrements de la table Employee.
orientdb> SELECT FROM employee WHERE name LIKE '%.P'
Si cette commande est exécutée avec succès, vous obtiendrez la sortie suivante.
---+-------+--------------------
# | ID | name
---+-------+--------------------
0 | 12 | satish.P
---+-------+--------------------
1 item(s) found. Query executed in 0.076 sec(s).
Vous pouvez maintenant utiliser la commande suivante pour annuler cette transaction.
orientdb> ROLLBACK
Vérifiez à nouveau la requête de sélection pour récupérer le même enregistrement de la table des employés.
orientdb> SELECT FROM employee WHERE name LIKE '%.P'
Si la restauration est exécutée avec succès, vous obtiendrez 0 enregistrement trouvé dans la sortie.
0 item(s) found. Query executed in 0.037 sec(s).
Selon la terminologie technique Optimizationsignifie "Obtenez les meilleures performances possibles dans les plus brefs délais." En ce qui concerne la base de données, l'optimisation consiste à maximiser la vitesse et l'efficacité avec lesquelles les données sont récupérées.
OrientDB prend en charge les arêtes légères, ce qui signifie une relation directe entre les entités de données. En termes simples, il s'agit d'une relation de champ à champ. OrientDB propose différentes manières d'optimiser la base de données. Il prend en charge la conversion des bords réguliers en bords légers.
L'instruction suivante est la syntaxe de base de la commande Optimiser la base de données.
OPTMIZE DATABASE [-lwedges] [-noverbose]
Où lwedges convertit les bords réguliers en bords légers et noverbose désactive la sortie.
Exemple
Dans cet exemple, nous utiliserons la même base de données nommée «demo» que nous avons créée dans le chapitre précédent. Vous pouvez utiliser la commande d'optimisation de base de données suivante.
OPTIMIZE DATABASE -lwedges
S'il est exécuté avec succès, vous recevrez des notifications réussies avec le message d'achèvement.
Database Optimization completed in 35ms
Semblable au SGBDR, OrientDB fournit la fonctionnalité permettant de supprimer une base de données. Drop database fait référence à la suppression complète d'une base de données.
L'instruction suivante est la syntaxe de base de la commande Drop database.
DROP DATABASE [<database-name> <server-username> <server-user-password>]
Voici les détails des options de la syntaxe ci-dessus.
<database-name> - Nom de la base de données que vous souhaitez supprimer.
<server-username> - Nom d'utilisateur de la base de données qui a le privilège de supprimer une base de données.
<server-user-password> - Mot de passe de l'utilisateur particulier.
Exemple
Il existe deux façons de supprimer une base de données, l'une consiste à supprimer une base de données actuellement ouverte et l'autre à supprimer une base de données particulière en fournissant le nom particulier.
Dans cet exemple, nous utiliserons la même base de données nommée «demo» que nous avons créée dans un chapitre précédent. Vous pouvez utiliser la commande suivante pour supprimer une base de donnéesdemo.
orientdb {db = demo}> DROP DATABASE
Si cette commande est exécutée avec succès, vous obtiendrez la sortie suivante.
Database 'demo' deleted successfully
OR
Vous pouvez utiliser une autre commande pour supprimer une base de données comme suit.
orientdb> DROP DATABASE PLOCAL:/opt/orientdb/databases/demo admin admin
Si cette commande est exécutée avec succès, vous obtiendrez la sortie suivante.
Database 'demo' deleted successfully
OrientDB est une base de données NoSQL qui peut stocker les documents et les données orientées graph. La base de données NoSQL ne contient aucune table, alors comment pouvez-vous insérer des données en tant qu'enregistrement. Ici, vous pouvez voir les données de la table sous la forme de classe, de propriété, de sommet et d'arête, ce qui signifie que les classes sont comme des tables et les propriétés sont comme des fichiers dans les tables.
Nous pouvons définir toutes ces entités en utilisant schemadans OrientDB. Les données de propriété peuvent être insérées dans une classe. La commande Insérer crée un nouvel enregistrement dans le schéma de base de données. Les enregistrements peuvent être sans schéma ou suivre certaines règles spécifiées.
L'instruction suivante est la syntaxe de base de la commande Insérer un enregistrement.
INSERT INTO [class:]<class>|cluster:<cluster>|index:<index>
[(<field>[,]*) VALUES (<expression>[,]*)[,]*]|
[SET <field> = <expression>|<sub-command>[,]*]|
[CONTENT {<JSON>}]
[RETURN <expression>]
[FROM <query>]
Voici les détails des options de la syntaxe ci-dessus.
SET - Définit chaque champ avec la valeur.
CONTENT- Définit les données JSON pour définir les valeurs de champ. Ceci est facultatif.
RETURN- Définit l'expression à renvoyer au lieu du nombre d'enregistrements insérés. Les cas d'utilisation les plus courants sont -
@rid - Renvoie l'ID d'enregistrement du nouvel enregistrement.
@this - Renvoie le nouvel enregistrement entier.
FROM - Où vous souhaitez insérer l'enregistrement ou un jeu de résultats.
Exemple
Considérons une table Customer avec les champs et types suivants.
Sr.No. | Nom de domaine | Type |
---|---|---|
1 | Id | Entier |
2 | Nom | Chaîne |
3 | Âge | Entier |
Vous pouvez créer le schéma (table) en exécutant les commandes suivantes.
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
Après avoir exécuté toutes les commandes, vous obtiendrez le nom de la table Client avec les champs id, nom et âge. Vous pouvez vérifier la table en exécutant une requête de sélection dans la table Customer.
OrientDB propose différentes manières d'insérer un enregistrement. Considérez la table Client suivante contenant les exemples d'enregistrements.
Sr.No. | Nom | Âge |
---|---|---|
1 | Satish | 25 |
2 | Krishna | 26 |
3 | Kiran | 29 |
4 | Javeed | 21 |
5 | Raja | 29 |
La commande suivante consiste à insérer le premier enregistrement dans la table Customer.
INSERT INTO Customer (id, name, age) VALUES (01,'satish', 25)
Si la commande ci-dessus est exécutée avec succès, vous obtiendrez la sortie suivante.
Inserted record 'Customer#11:0{id:1,name:satish,age:25} v1' in 0.069000 sec(s).
La commande suivante consiste à insérer le deuxième enregistrement dans la table Client.
INSERT INTO Customer SET id = 02, name = 'krishna', age = 26
Si la commande ci-dessus est exécutée avec succès, vous obtiendrez la sortie suivante.
Inserted record 'Customer#11:1{id:2,age:26,name:krishna} v1' in 0.005000 sec(s).
La commande suivante consiste à insérer le troisième enregistrement dans la table Client.
INSERT INTO Customer CONTENT {"id": "03", "name": "kiran", "age": "29"}
Si la commande ci-dessus est exécutée avec succès, vous obtiendrez la sortie suivante.
Inserted record 'Customer#11:2{id:3,name:kiran,age:29} v1' in 0.004000 sec(s).
La commande suivante consiste à insérer les deux enregistrements suivants dans la table Client.
INSERT INTO Customer (id, name, age) VALUES (04,'javeed', 21), (05,'raja', 29)
Si la commande ci-dessus est exécutée avec succès, vous obtiendrez la sortie suivante.
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).
Vous pouvez vérifier si tous ces enregistrements sont insérés ou non en exécutant la commande suivante.
SELECT FROM Customer
Si la commande ci-dessus est exécutée avec succès, vous obtiendrez la sortie suivante.
----+-----+--------+----+-------+----
# |@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
----+-----+--------+----+-------+----
Semblable au SGBDR, OrientDB prend en charge différents types de requêtes SQL pour récupérer les enregistrements de la base de données. Lors de la récupération des enregistrements, nous avons différentes variantes ou options de requêtes avec l'instruction select.
L'instruction suivante est la syntaxe de base de la commande 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 ]
Voici les détails des options de la syntaxe ci-dessus.
<Projections> - Indique les données que vous souhaitez extraire de la requête en tant que jeu d'enregistrements de résultats.
FROM- Indique l'objet à interroger. Cela peut être une classe, un cluster, un ID d'enregistrement unique, un ensemble d'ID d'enregistrement. Vous pouvez spécifier tous ces objets comme cible.
WHERE - Spécifie la condition pour filtrer l'ensemble de résultats.
LET - Indique la variable de contexte utilisée dans les projections, les conditions ou les sous-requêtes.
GROUP BY - Indique le champ pour regrouper les enregistrements.
ORDER BY - Indique le fichier pour organiser un enregistrement dans l'ordre.
UNWIND - Désigne le champ sur lequel dérouler la collection d'enregistrements.
SKIP - Définit le nombre d'enregistrements que vous souhaitez ignorer depuis le début du jeu de résultats.
LIMIT - Indique le nombre maximum d'enregistrements dans l'ensemble de résultats.
FETCHPLAN - Spécifie la stratégie définissant la manière dont vous souhaitez récupérer les résultats.
TIMEOUT - Définit la durée maximale en millisecondes de la requête.
LOCK- Définit la stratégie de verrouillage. DEFAULT et RECORD sont les stratégies de verrouillage disponibles.
PARALLEL - Exécute la requête sur les threads simultanés 'x'.
NOCACHE - Définit si vous souhaitez utiliser le cache ou non.
Exemple
Considérons la table Customer suivante créée dans le chapitre précédent.
Sr.No. | Nom | Âge |
---|---|---|
1 | Satish | 25 |
2 | Krishna | 26 |
3 | Kiran | 29 |
4 | Javeed | 21 |
5 | Raja | 29 |
Essayez différentes requêtes de sélection pour récupérer les enregistrements de données de la table Client.
Method 1 - Vous pouvez utiliser la requête suivante pour sélectionner tous les enregistrements de la table Client.
orientdb {db = demo}> SELECT FROM Customer
Si la requête ci-dessus est exécutée avec succès, vous obtiendrez la sortie suivante.
----+-----+--------+----+-------+----
# |@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 - Sélectionnez tous les enregistrements dont le nom commence par la lettre 'k».
orientdb {db = demo}> SELECT FROM Customer WHERE name LIKE 'k%'
OU vous pouvez utiliser la requête suivante pour l'exemple ci-dessus.
orientdb {db = demo}> SELECT FROM Customer WHERE name.left(1) = 'k'
Si la requête ci-dessus est exécutée avec succès, vous obtiendrez la sortie suivante.
----+-----+--------+----+-------+----
# |@RID |@CLASS |id |name |age
----+-----+--------+----+-------+----
0 |#11:1|Customer|2 |krishna|26
1 |#11:2|Customer|3 |kiran |29
----+-----+--------+----+-------+----
Method 3 - Sélectionnez id, noms des enregistrements de la table Client avec des noms en majuscules.
orientdb {db = demo}> SELECT id, name.toUpperCase() FROM Customer
Si la requête ci-dessus est exécutée avec succès, vous obtiendrez la sortie suivante.
----+--------+----+-------
# |@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 - Sélectionnez tous les enregistrements de la table Client dont l'âge est compris entre 25 et 29 ans.
orientdb {db = demo}> SELECT FROM Customer WHERE age in [25,29]
Si la requête ci-dessus est exécutée avec succès, vous obtiendrez la sortie suivante.
----+-----+--------+----+-------+----
# |@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 - Sélectionnez tous les enregistrements de la table Client où n'importe quel champ contient le mot «sh».
orientdb {db = demo}> SELECT FROM Customer WHERE ANY() LIKE '%sh%'
Si la requête ci-dessus est exécutée avec succès, vous obtiendrez la sortie suivante.
----+-----+--------+----+-------+----
# |@RID |@CLASS |id |name |age
----+-----+--------+----+-------+----
0 |#11:0|Customer|1 |satish |25
1 |#11:1|Customer|2 |krishna|26
----+-----+--------+----+-------+----
Method 6 - Sélectionnez tous les enregistrements de la table Client, classés par âge dans l'ordre décroissant.
orientdb {db = demo}> SELECT FROM Customer ORDER BY age DESC
Si la requête ci-dessus est exécutée avec succès, vous obtiendrez la sortie suivante.
----+-----+--------+----+-------+----
# |@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 Recordest utilisé pour charger un enregistrement particulier à partir du schéma. Charger l'enregistrement chargera l'enregistrement à l'aide de Record ID. Il est représenté par@rid symbole dans le jeu de résultats.
L'instruction suivante est la syntaxe de base de la commande LOAD Record.
LOAD RECORD <record-id>
Où <record-id> définit l'ID d'enregistrement de l'enregistrement que vous souhaitez charger.
Si vous ne connaissez pas l'ID d'enregistrement d'un enregistrement particulier, vous pouvez exécuter n'importe quelle requête sur la table. Dans l'ensemble de résultats, vous trouverez l'ID d'enregistrement (@rid) de l'enregistrement respectif.
Exemple
Considérons la même table Client que nous avons utilisée dans les chapitres précédents.
Sr.No. | Nom | Âge |
---|---|---|
1 | Satish | 25 |
2 | Krishna | 26 |
3 | Kiran | 29 |
4 | Javeed | 21 |
5 | Raja | 29 |
Essayez la requête suivante pour récupérer l'enregistrement ayant l'ID d'enregistrement @rid: #11:0.
orientdb {db = demo}> LOAD RECORD #11:0
Si la requête ci-dessus est exécutée avec succès, vous obtiendrez la sortie suivante.
+---------------------------------------------------------------------------+
| Document - @class: Customer @rid: #11:0 @version: 1 |
+---------------------------------------------------------------------------+
| Name | Value |
+---------------------------------------------------------------------------+
| id | 1 |
| name | satish |
| age | 25 |
+---------------------------------------------------------------------------+
Reload Recordfonctionne également de manière similaire à la commande Charger l'enregistrement et est également utilisée pour charger un enregistrement particulier à partir du schéma. Charger l'enregistrement chargera l'enregistrement à l'aide de Record ID. Il est représenté par@ridsymbole dans le jeu de résultats. La principale différence est que Recharger l'enregistrement ignore le cache, ce qui est utile lorsque des transactions simultanées externes sont appliquées pour modifier l'enregistrement. Il donnera la dernière mise à jour.
L'instruction suivante est la syntaxe de base de la commande RELOAD Record.
RELOAD RECORD <record-id>
Où <record-id> définit l'ID d'enregistrement de l'enregistrement que vous souhaitez recharger.
Si vous ne connaissez pas l'ID d'enregistrement d'un enregistrement particulier, vous pouvez exécuter n'importe quelle requête sur la table. Dans l'ensemble de résultats, vous trouverez l'ID d'enregistrement (@rid) de l'enregistrement respectif.
Exemple
Considérons la même table Customer que nous avons utilisée dans le chapitre précédent.
Sr.No. | Nom | Âge |
---|---|---|
1 | Satish | 25 |
2 | Krishna | 26 |
3 | Kiran | 29 |
4 | Javeed | 21 |
5 | Raja | 29 |
Essayez la requête suivante pour récupérer l'enregistrement ayant l'ID d'enregistrement @rid: #11:0.
orientdb {db = demo}> LOAD RECORD #11:0
Si la requête ci-dessus est exécutée avec succès, vous obtiendrez la sortie suivante.
+---------------------------------------------------------------------------+
| Document - @class: Customer @rid: #11:0 @version: 1 |
+---------------------------------------------------------------------------+
| Name | Value |
+---------------------------------------------------------------------------+
| id | 1 |
| name | satish |
| age | 25 |
+---------------------------------------------------------------------------+
Export Recordest la commande utilisée pour exporter l'enregistrement chargé dans le format demandé et pris en charge. Si vous exécutez une syntaxe incorrecte, la liste des formats pris en charge s'affiche. OrientDB est une famille de bases de données de documents, par conséquent JSON est le format pris en charge par défaut.
L'instruction suivante est la syntaxe de base de la commande Export Record.
EXPORT RECORD <format>
Où <Format> définit le format dans lequel vous souhaitez obtenir l'enregistrement.
Note - La commande d'exportation exportera l'enregistrement chargé en fonction de l'ID d'enregistrement.
Exemple
Considérons la même table Customer que nous avons utilisée dans le chapitre précédent.
Sr.No. | Nom | Âge |
---|---|---|
1 | Satish | 25 |
2 | Krishna | 26 |
3 | Kiran | 29 |
4 | Javeed | 21 |
5 | Raja | 29 |
Essayez la requête suivante pour récupérer l'enregistrement ayant l'ID d'enregistrement @rid: #11:0.
orientdb {db = demo}> LOAD RECORD #11:0
Si la requête ci-dessus est exécutée avec succès, vous obtiendrez la sortie suivante.
+---------------------------------------------------------------------------+
| Document - @class: Customer @rid: #11:0 @version: 1 |
+---------------------------------------------------------------------------+
| Name | Value |
+---------------------------------------------------------------------------+
| id | 1 |
| name | satish |
| age | 25 |
+---------------------------------------------------------------------------+
Utilisez la requête suivante pour exporter l'enregistrement chargé (# 11: 0) au format JSON.
orientdb {db = demo}> EXPORT RECORD json
Si la requête ci-dessus est exécutée avec succès, vous obtiendrez la sortie suivante.
{
"@type": "d",
"@rid": "#11:0",
"@version": 1,
"@class": "Customer",
"id": 1,
"name": "satish",
"age": 25
}
Update RecordLa commande est utilisée pour modifier la valeur d'un enregistrement particulier. SET est la commande de base pour mettre à jour une valeur de champ particulière.
L'instruction suivante est la syntaxe de base de la commande 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>]
Voici les détails des options de la syntaxe ci-dessus.
SET - Définit le champ à mettre à jour.
INCREMENT - Incrémente la valeur du champ spécifié de la valeur donnée.
ADD - Ajoute le nouvel élément dans les champs de collection.
REMOVE - Supprime un élément du champ de collection.
PUT - Met une entrée dans le champ de la carte.
CONTENT - Remplace le contenu de l'enregistrement par le contenu du document JSON.
MERGE - Fusionne le contenu de l'enregistrement avec un document JSON.
LOCK- Spécifie comment verrouiller les enregistrements entre le chargement et la mise à jour. Nous avons deux options à spécifierDefault et Record.
UPSERT- Met à jour un enregistrement s'il existe ou insère un nouvel enregistrement dans le cas contraire. Il aide à exécuter une seule requête au lieu d'exécuter deux requêtes.
RETURN - Spécifie une expression à renvoyer au lieu du nombre d'enregistrements.
LIMIT - Définit le nombre maximum d'enregistrements à mettre à jour.
TIMEOUT - Définit la durée pendant laquelle vous souhaitez autoriser l'exécution de la mise à jour avant son expiration.
Exemple
Considérons la même table Customer que nous avons utilisée dans le chapitre précédent.
Sr.No. | Nom | Âge |
---|---|---|
1 | Satish | 25 |
2 | Krishna | 26 |
3 | Kiran | 29 |
4 | Javeed | 21 |
5 | Raja | 29 |
Essayez la requête suivante pour mettre à jour l'âge d'un client «Raja».
Orientdb {db = demo}> UPDATE Customer SET age = 28 WHERE name = 'Raja'
Si la requête ci-dessus est exécutée avec succès, vous obtiendrez la sortie suivante.
Updated 1 record(s) in 0.008000 sec(s).
Pour vérifier l'enregistrement de la table Customer, vous pouvez utiliser la requête suivante.
orientdb {db = demo}> SELECT FROM Customer
Si la requête ci-dessus est exécutée avec succès, vous obtiendrez la sortie suivante.
----+-----+--------+----+-------+----
# |@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 La commande est utilisée pour supprimer les valeurs d'un enregistrement particulier.
L'instruction suivante est la syntaxe de base de la commande Truncate.
TRUNCATE RECORD <rid>*
Où <rid>* indique l'ID d'enregistrement à tronquer. Vous pouvez utiliser plusieurs Rids séparés par une virgule pour tronquer plusieurs enregistrements. Il renvoie le nombre d'enregistrements tronqués.
Exemple
Considérons la même table Customer que nous avons utilisée dans le chapitre précédent.
Sr.No. | Nom | Âge |
---|---|---|
1 | Satish | 25 |
2 | Krishna | 26 |
3 | Kiran | 29 |
4 | Javeed | 21 |
5 | Raja | 28 |
Essayez la requête suivante pour tronquer l'enregistrement ayant l'ID d'enregistrement # 11: 4.
Orientdb {db = demo}> TRUNCATE RECORD #11:4
Si la requête ci-dessus est exécutée avec succès, vous obtiendrez la sortie suivante.
Truncated 1 record(s) in 0.008000 sec(s).
Pour vérifier l'enregistrement de la table Customer, vous pouvez utiliser la requête suivante.
Orientdb {db = demo}> SELECT FROM Customer
Si la requête ci-dessus est exécutée avec succès, vous obtiendrez la sortie suivante.
----+-----+--------+----+-------+----
# |@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 La commande est utilisée pour supprimer complètement un ou plusieurs enregistrements de la base de données.
L'instruction suivante est la syntaxe de base de la commande Supprimer.
DELETE FROM <Class>|cluster:<cluster>|index:<index>
[LOCK <default|record>]
[RETURN <returning>]
[WHERE <Condition>*]
[LIMIT <MaxRecords>]
[TIMEOUT <timeout>]
Voici les détails des options de la syntaxe ci-dessus.
LOCK- Spécifie comment verrouiller les enregistrements entre le chargement et la mise à jour. Nous avons deux options à spécifierDefault et Record.
RETURN - Spécifie une expression à renvoyer au lieu du nombre d'enregistrements.
LIMIT - Définit le nombre maximum d'enregistrements à mettre à jour.
TIMEOUT - Définit la durée pendant laquelle vous souhaitez autoriser l'exécution de la mise à jour avant son expiration.
Note - N'utilisez pas DELETE pour supprimer les sommets ou les arêtes car cela affecte l'intégrité du graphe.
Exemple
Considérons la table Client.
Sr.No. | Nom | Âge |
---|---|---|
1 | Satish | 25 |
2 | Krishna | 26 |
3 | Kiran | 29 |
4 | Javeed | 21 |
Essayez la requête suivante pour supprimer l'enregistrement ayant l'ID = 4.
orientdb {db = demo}> DELETE FROM Customer WHERE id = 4
Si la requête ci-dessus est exécutée avec succès, vous obtiendrez la sortie suivante.
Delete 1 record(s) in 0.008000 sec(s).
Pour vérifier l'enregistrement de la table Customer, vous pouvez utiliser la requête suivante.
Orientdb {db = demo}> SELECT FROM Customer
Si la requête ci-dessus est exécutée avec succès, vous obtiendrez la sortie suivante.
----+-----+--------+----+-------+----
# |@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 prend en charge la fonctionnalité multimodèle et propose différentes manières d'aborder et de comprendre les concepts de base d'une base de données. Cependant, nous pouvons facilement accéder à ces modèles du point de vue de l'API de base de données de documents. Comme le SGBDR, OrientDB utilise également le Record comme élément de stockage mais il utilise le type Document. Les documents sont stockés sous forme de paires clé / valeur. Nous stockons les champs et les propriétés sous forme de paires clé / valeur appartenant à une classe de concepts.
Classest un type de modèle de données et le concept est tiré du paradigme de programmation orientée objet. Sur la base du modèle de base de données documentaire traditionnel, les données sont stockées sous forme de collection, tandis que dans le modèle de base de données relationnelle, les données sont stockées dans des tables. OrientDB suit l'API Document avec le paradigme OPPS. En tant que concept, la classe dans OrientDB a la relation la plus proche avec la table dans les bases de données relationnelles, mais (contrairement aux tables) les classes peuvent être sans schéma, complètes ou mixtes. Les classes peuvent hériter d'autres classes, créant des arbres de classes. Chaque classe a son ou ses propres clusters (créés par défaut, si aucun n'est défini).
L'instruction suivante est la syntaxe de base de la commande Create Class.
CREATE CLASS <class>
[EXTENDS <super-class>]
[CLUSTER <cluster-id>*]
[CLUSTERS <total-cluster-number>]
[ABSTRACT]
Voici les détails des options de la syntaxe ci-dessus.
<class> - Définit le nom de la classe que vous souhaitez créer.
<super-class> - Définit la super-classe que vous souhaitez étendre avec cette classe.
<total-cluster-number>- Définit le nombre total de clusters utilisés dans cette classe. La valeur par défaut est 1.
ABSTARCT- Définit que la classe est abstraite. Ceci est facultatif.
Exemple
Comme discuté, la classe est un concept lié à la table. C'est pourquoi nous allons créer ici un compte de table. Cependant, lors de la création d'une classe, nous ne pouvons pas définir de champs, c'est-à-dire des propriétés basées sur le paradigme OOPS.
La commande suivante consiste à créer une classe nommée Account.
orientdb> CREATE CLASS Account
Si la commande ci-dessus est exécutée avec succès, vous obtiendrez la sortie suivante.
Class created successfully
Vous pouvez utiliser la commande suivante pour créer une classe Car qui s'étend à la classe Vehicle.
orientdb> CREATE CLASS Car EXTENDS Vehicle
Si la commande ci-dessus est exécutée avec succès, vous obtiendrez la sortie suivante.
Class created successfully
Vous pouvez utiliser la commande suivante pour créer une classe Person en tant que résumé.
orientdb> CREATE CLASS Person ABSTRACT
Si la commande ci-dessus est exécutée avec succès, vous obtiendrez la sortie suivante.
Class created successfully
Note- Sans avoir de propriétés, la classe est inutile et incapable de construire un objet réel. Dans les chapitres suivants, vous pouvez apprendre à créer des propriétés pour une classe particulière.
La classe et la propriété dans OrientDB sont utilisées pour créer un schéma avec les attributs respectifs tels que le nom de classe, la super-classe, le cluster, le nombre de clusters, le résumé, etc. Si vous souhaitez modifier ou mettre à jour un attribut de classes existantes dans le schéma, alors tu dois utiliser Alter Class commander.
L'instruction suivante est la syntaxe de base de la commande Alter Class.
ALTER CLASS <class> <attribute-name> <attribute-value>
Voici les détails des options de la syntaxe ci-dessus.
<class> - Définit le nom de la classe.
<attribute-name> - Définit l'attribut que vous souhaitez modifier.
<attribute-value> - Définit la valeur que vous souhaitez définir pour l'attribut.
Le tableau suivant définit la liste des attributs qui prennent en charge la commande Alter Class.
Attribut | Type | La description |
---|---|---|
NOM | Chaîne | Modifie le nom de la classe. |
NOM COURT | Chaîne | Définit un nom court (c'est-à-dire un alias) pour la classe. Utilisez NULL pour supprimer une attribution de nom court. |
SUPERCLASS | Chaîne | Définit une super-classe pour la classe. Pour ajouter une nouvelle classe, vous pouvez utiliser la syntaxe + <classe>, pour la supprimer utilisez - <classe>. |
OVERSIZE | Nombre décimal | Définit le facteur de surdimensionnement. |
ADDCLUSTER | Chaîne | Ajoute un cluster à la classe. Si le cluster n'existe pas, il crée un cluster physique. L'ajout de clusters à une classe est également utile pour stocker des enregistrements dans des serveurs distribués. |
REMOVECLUSTER | Chaîne | Supprime un cluster d'une classe. Il ne supprime pas le cluster, mais le supprime seulement de la classe. |
STRICTMODE | - | Active ou désactive le mode strict. En mode strict, vous travaillez en mode complet de schéma et ne pouvez pas ajouter de nouvelles propriétés à un enregistrement si elles font partie de la définition de schéma de la classe. |
CLUSTERSELECTION | - | Définit la stratégie de sélection lors du choix du cluster à utiliser pour les nouveaux enregistrements. |
DOUANE | - | Définit les propriétés personnalisées. Les noms et valeurs de propriété doivent suivre la syntaxe <propertyname> = <value> sans espaces entre le nom et la valeur. |
ABSTRAIT | Booléen | Convertit la classe en classe abstraite ou l'inverse. |
Exemple
Essayons quelques exemples qui mettront à jour ou modifieront les attributs de la classe existante.
La requête suivante est utilisée pour définir une super-classe 'Person' pour une classe existante 'Employee'.
orientdb> ALTER CLASS Employee SUPERCLASS Person
Si la requête ci-dessus est exécutée avec succès, vous obtiendrez la sortie suivante.
Class altered successfully
La requête suivante est utilisée pour ajouter une super-classe 'Person' pour une classe existante 'Employee'.
orientdb> ALTER CLASS Employee SUPERCLASS +Person
Si la requête ci-dessus est exécutée avec succès, vous obtiendrez la sortie suivante.
Class altered successfully
Truncate classsupprimera tous les enregistrements des clusters définis comme faisant partie de la classe. Dans OrientDB, chaque classe a un cluster associé avec le même nom. Si vous souhaitez également supprimer tous les enregistrements de la hiérarchie des classes, vous devez utiliser le mot clé POLYMORPHIC.
L'instruction suivante est la syntaxe de base de Truncate Class Command.
TRUNCATE CLASS <class> [ POLYMORPHIC ] [ UNSAFE ]
Voici les détails des options de la syntaxe ci-dessus.
<class> - Définit la classe que vous souhaitez tronquer.
POLYMORPHIC - Définit si la commande tronque également la hiérarchie.
UNSAFE - Définit la commande force la troncature sur le sommet ou la classe d'arête.
Exemple
La requête suivante pour tronquer une classe Profile.
orientdb> TRUNCATE CLASS Profile
Si la requête ci-dessus est exécutée avec succès, vous obtiendrez la sortie suivante.
Class truncated successfully
le Drop ClassLa commande supprime une classe du schéma. Il est important de faire attention et de maintenir un schéma cohérent. Par exemple, évitez de supprimer des classes qui sont des super-classes d'autres. Le cluster associé ne sera pas supprimé.
L'instruction suivante est la syntaxe de base de la commande Drop Class.
DROP CLASS <class>
Supprimez une classe avec le nom de la classe.
Exemple
Essayez la requête suivante pour supprimer un employé de classe.
Orientdb> DROP CLASS Employee
Si la requête ci-dessus est exécutée avec succès, vous obtiendrez la sortie suivante.
Class dropped successfully
Clusterest un concept important dans OrientDB qui est utilisé pour stocker des enregistrements, des documents ou des sommets. En termes simples, le cluster est un endroit où un groupe d'enregistrements est stocké. Par défaut, OrientDB créera un cluster par classe. Tous les enregistrements d'une classe sont stockés dans le même cluster, qui porte le même nom que la classe. Vous pouvez créer jusqu'à 32 767 clusters (2 ^ 15-1) dans une base de données.
La classe CREATE est une commande utilisée pour créer un cluster avec un nom spécifique. Une fois le cluster créé, vous pouvez utiliser le cluster pour enregistrer des enregistrements en spécifiant le nom lors de la création de tout modèle de données. Si vous souhaitez ajouter un nouveau cluster à une classe, utilisez la commande Alter Class et la commande ADDCLUSTER.
L'instruction suivante est la syntaxe de base de la commande Créer un cluster.
CREATE CLUSTER <cluster> [ID <cluster-id>]
Où <cluster> définit le nom du cluster que vous souhaitez créer et <cluster-id> définit l'ID numérique que vous souhaitez utiliser pour le cluster.
Le tableau suivant fournit la liste des stratégies de sélection de cluster.
Sr.No. | Stratégie et description |
---|---|
1 | Default Sélectionne le cluster à l'aide de la propriété de classe ClusterId par défaut. |
2 | Round-robin Sélectionne le cluster suivant dans un ordre circulaire. Il redémarre une fois terminé. |
3 | Balanced Sélectionne le plus petit cluster. Permet à la classe d'avoir tous les clusters sous-jacents équilibrés en taille. Lors de l'ajout d'un nouveau cluster à une classe existante, il remplit d'abord le nouveau cluster. |
Exemple
Prenons un exemple pour créer un cluster nommé sales.
orientdb> CREATE CLUSTER sales
Si la requête ci-dessus est exécutée avec succès, vous obtiendrez la sortie suivante.
Cluster created correctly with id #12
Alter ClusterLa commande consiste à mettre à jour les attributs sur un cluster existant. Dans ce chapitre, vous pouvez apprendre comment ajouter ou modifier les attributs d'un cluster.
L'instruction suivante est la syntaxe de base de la commande Alter Cluster.
ALTER CLUSTER <cluster> <attribute-name> <attribute-value>
Voici les détails des options de la syntaxe ci-dessus.
<cluster> - Définit le nom du cluster.
<attribute-name> - Définit l'attribut que vous souhaitez modifier.
<attribute-value> - Définit la valeur que vous souhaitez définir pour cet attribut.
Le format tabulaire suivant fournit la liste des attributs pris en charge que vous pouvez utiliser avec la commande Alter cluster.
Nom | Type | La description |
---|---|---|
NOM | Chaîne | Modifie le nom du cluster. |
STATUT | Chaîne | Modifie l'état du cluster. Les valeurs autorisées sont EN LIGNE et HORS LIGNE. Par défaut, les clusters sont en ligne. |
COMPRESSION | Chaîne | Définit le type de compression à utiliser. Les valeurs autorisées sont NOTHING, SNAPPY, GZIP et tout autre type de compression enregistré dans la classe OCompressionFactory. |
USE_WAL | Booléen | Définit s'il utilise le Journal lorsque OrientDB opère sur le cluster |
RECORD_GROW_FACTO R | Entier | Définit le facteur de croissance pour économiser plus d'espace lors de la création d'enregistrement. Cela peut vous être utile lorsque vous mettez à jour l'enregistrement avec des informations supplémentaires. |
RECORD_OVERFLOW_GR OW_FACTOR | Entier | Définit le facteur de croissance sur les mises à jour. Lorsqu'il atteint la limite de taille, il utilise ce paramètre pour obtenir plus d'espace, (facteur> 1). |
STRATÉGIE DE CONFLIT | Chaîne | Définit la stratégie qu'il utilise pour gérer les conflits dans le cas où OrientDB MVCC trouve une mise à jour ou une opération de suppression qu'il exécute sur un ancien enregistrement. |
Le tableau suivant fournit la liste des stratégies de conflit.
Sr.No. | Stratégie et description |
---|---|
1 | Version Lève une exception lorsque les versions sont différentes. Ce sont les paramètres par défauts. |
2 | Content Dans le cas où les versions sont différentes, il vérifie les changements dans le contenu, sinon il utilise la version la plus élevée pour éviter de lever une exception. |
3 | Automerge Fusionne les modifications. |
Exemple
Essayez les exemples de requêtes suivants pour apprendre la commande Alter cluster.
Exécutez la commande suivante pour changer le nom d'un cluster de Employee à Employee2.
orientdb {db = demo}> ALTER CLUSTER Employee NAME Employee2
Si la commande ci-dessus est exécutée avec succès, vous obtiendrez la sortie suivante.
Cluster updated successfully
Exécutez la commande suivante pour changer le nom d'un cluster de Employee2 en Employee à l'aide de l'ID de cluster.
orientdb {db = demo}> ALTER CLUSTER 12 NAME Employee
Si la commande ci-dessus est exécutée avec succès, vous obtiendrez la sortie suivante.
Cluster updated successfully
Exécutez la commande suivante pour modifier la stratégie de conflit de cluster pour fusionner automatiquement.
orientdb {db = demo}> ALTER CLUSTER V CONFICTSTRATEGY automerge
Si la commande ci-dessus est exécutée avec succès, vous obtiendrez la sortie suivante.
Cluster updated successfully
le Truncate Cluster La commande supprime tous les enregistrements d'un cluster.
L'instruction suivante est la syntaxe de base de Truncate Cluster Command.
TRUNCATE CLUSTER <cluster-name>
Où <cluster-name> est le nom du cluster.
Exemple
Essayez la requête suivante pour tronquer le cluster nommé sales.
Orientdb {db = demo}> TRUNCATE CLUSTER Profile
Si la requête ci-dessus est exécutée avec succès, vous obtiendrez la sortie suivante.
Cluster truncated successfully.
le Drop ClusterLa commande supprime le cluster et tout son contenu associé. Cette opération est permanente et rollback.
L'instruction suivante est la syntaxe de base de la commande Drop Cluster.
DROP CLUSTER <cluster-name>|<cluster-id>
Où <cluster-name> définit le nom du cluster que vous souhaitez supprimer et <cluster-id> définit l'ID du cluster que vous souhaitez supprimer.
Exemple
Essayez la commande suivante pour supprimer le cluster Sales.
orientdb> DROP CLUSTER Sales
Si la requête ci-dessus est exécutée avec succès, vous obtiendrez la sortie suivante.
Cluster dropped successfully
Propertydans OrientDB fonctionne comme un champ de classe et de colonne dans la table de base de données. Create Property est une commande utilisée pour créer une propriété pour une classe particulière. Le nom de classe que vous avez utilisé dans la commande doit exister.
L'instruction suivante est la syntaxe de base de la commande Créer une propriété.
CREATE PROPERTY <class-name>.<property-name> <property-type> [<linked-type>][ <linked-class>]
Voici les détails des options de la syntaxe ci-dessus.
<class-name> - Définit la classe dans laquelle vous souhaitez créer la propriété.
<property-name> - Définit le nom logique de la propriété.
<property-type> - Définit le type de propriété que vous souhaitez créer.
<linked-type> - Définit le type de conteneur, utilisé dans le type de propriété de conteneur.
<linked-class> - Définit la classe de conteneur, utilisée dans le type de propriété de conteneur.
Le tableau suivant fournit le type de données pour la propriété afin qu'OrientDB connaisse le type de données à stocker.
BOOLÉEN | ENTIER | COURT | LONGUE |
FLOTTE | DATE | CHAÎNE | INTÉGRÉ |
LIEN | OCTET | BINAIRE | DOUBLE |
En plus de ceux-ci, il existe plusieurs autres types de propriétés qui fonctionnent comme des conteneurs.
LISTE INTÉGRÉE | EMBEDDEDSET | EMBEDDEDMAP |
LISTE DE LIENS | LINKSET | LINKMAP |
Exemple
Essayez l'exemple suivant pour créer un nom de propriété sur la classe Employee, du type String.
orientdb> CREATE PROPERTY Employee.name STRING
Si la requête ci-dessus est exécutée avec succès, vous obtiendrez la sortie suivante.
Property created successfully with id = 1
Alter Propertyest une commande utilisée pour modifier ou mettre à jour la propriété d'une classe particulière. Modifier la propriété signifie modifier les champs d'une table. Dans ce chapitre, vous pouvez apprendre à mettre à jour la propriété.
L'instruction suivante est la syntaxe de base de Alter Property Command.
ALTER PROPERTY <class>.<property> <attribute-name> <attribute-value>
Voici les détails des options de la syntaxe ci-dessus.
<class> - Définit la classe à laquelle appartient la propriété.
<property> - Définit la propriété que vous souhaitez mettre à jour.
<attribute-name> - Définit l'attribut d'une propriété que vous souhaitez mettre à jour.
<attribute-value> - Définit la valeur que vous souhaitez définir sur l'attribut.
Le tableau suivant définit la liste des attributs pour modifier la propriété.
Attribut | Type | La description |
---|---|---|
LINKEDCLASS | Chaîne | Définit le nom de la classe liée. Utilisez NULL pour supprimer une valeur existante. |
LINKEDTYPE | Chaîne | Définit le type de lien. Utilisez NULL pour supprimer une valeur existante. |
MIN | Entier | Définit la valeur minimale comme contrainte. Utilisez NULL pour supprimer une contrainte existante. |
OBLIGATOIRE | Booléen | Définit si la propriété nécessite une valeur. |
MAX | Entier | Définit la valeur maximale comme contrainte. Utilisez NULL pour supprimer une contrainte existante. |
NOM | Chaîne | Définit le nom de la propriété. |
NOTNULL | Booléen | Définit si la propriété peut avoir une valeur NULL. |
REGEX | Chaîne | Définit une expression régulière comme contrainte. Utilisez NULL pour supprimer une contrainte existante. |
TYPE | Chaîne | Définit un type de propriété. |
COLLATIONNER | Chaîne | Les ensembles sont assemblés selon l'une des stratégies de comparaison définies. Par défaut, il est défini sur sensible à la casse (cs). Vous pouvez également le définir sur insensible à la casse (ci). |
LECTURE SEULEMENT | Booléen | Définit si la valeur de la propriété est immuable. Autrement dit, s'il est possible de le modifier après la première affectation. À utiliser avec DEFAULT pour avoir des valeurs immuables lors de la création. |
DOUANE | Chaîne | Définit les propriétés personnalisées. La syntaxe des propriétés personnalisées est <custom-name> = <custom-value>, comme stéréotype = icon. |
DÉFAUT | Définit la valeur ou la fonction par défaut. |
Note - si vous modifiez NAME ou TYPE, la mise à jour de cette commande prendra un certain temps en fonction de la quantité de données.
Exemple
Essayez quelques requêtes ci-dessous pour comprendre la propriété Alter.
Exécutez la requête suivante pour changer le nom de la propriété de «age» à «born» dans la classe Customer.
orinetdb {db = demo}> ALTER PROPERTY Customer.age NAME born
Si la requête ci-dessus est exécutée avec succès, vous obtiendrez la sortie suivante.
Property altered successfully
Exécutez la requête suivante pour faire de «nom» la propriété obligatoire de la classe «Client».
orientdb {db = demo}> ALTER PROPERTY Customer.name MANDATORY TRUE
Si la requête ci-dessus est exécutée avec succès, vous obtiendrez la sortie suivante.
Property altered successfully
le Drop propertyLa commande supprime la propriété du schéma. Il ne supprime pas les valeurs de propriété de l'enregistrement, il modifie simplement le schéma.
L'instruction suivante est la syntaxe de base de Drop Property Command.
DROP PROPERTY <class>.<property> [FORCE]
Voici les détails des options de la syntaxe ci-dessus.
<class> - Définit la classe dans laquelle la propriété existe.
<property> - Définit la propriété que vous souhaitez supprimer.
[Force] - Dans le cas où un ou plusieurs index sont définis sur la propriété.
Exemple
Essayez la commande suivante pour supprimer la propriété 'age' de la classe 'Customer'.
orientdb> DROP PROPERTY Customer.age
Si la commande ci-dessus est exécutée avec succès, vous obtiendrez la sortie suivante.
Property dropped successfully
La base de données OrientDB n'est pas seulement une base de données Document, mais également une base de données Graph. De nouveaux concepts tels que Vertex et Edge sont utilisés pour stocker les données sous forme de graphique. Il applique le polymorphisme sur les sommets. La classe de base pour Vertex est V.
Dans ce chapitre, vous pouvez apprendre à créer des sommets pour stocker des données graphiques.
L'instruction suivante est la syntaxe de base de la commande Create Vertex.
CREATE VERTEX [<class>] [CLUSTER <cluster>] [SET <field> = <expression>[,]*]
Voici les détails des options de la syntaxe ci-dessus.
<class> - Définit la classe à laquelle appartient le sommet.
<cluster> - Définit le cluster dans lequel il stocke le sommet.
<field> - Définit le champ que vous souhaitez définir.
<expression> - Définit l'express à définir pour le champ.
Exemple
Essayez l'exemple suivant pour comprendre comment créer un sommet.
Exécutez la requête suivante pour créer un sommet sans 'nom' et sur la classe de base V.
orientdb> CREATE VERTEX
Si la requête ci-dessus est exécutée avec succès, vous obtiendrez la sortie suivante.
Created vertex 'V#9:0 v1' in 0.118000 sec(s)
Exécutez la requête suivante pour créer une nouvelle classe de vertex nommée v1, puis créez un vertex dans cette classe.
orientdb> CREATE CLASS V1 EXTENDS V
orientdb> CREATE VERTEX V1
Si la requête ci-dessus est exécutée avec succès, vous obtiendrez la sortie suivante.
Created vertex 'V1#14:0 v1' in 0.004000 sec(s)
Exécutez la requête suivante pour créer un nouveau sommet de la classe nommée v1, en définissant ses propriétés telles que brand = 'Maruti' et name = 'Swift'.
orientdb> CREATE VERTEX V1 SET brand = 'maruti', name = 'swift'
Si la requête ci-dessus est exécutée avec succès, vous obtiendrez la sortie suivante.
Created vertex 'V1#14:1{brand:maruti,name:swift} v1' in 0.004000 sec(s)
La commande Déplacer le sommet dans OrientDB consiste à déplacer un ou plusieurs sommets de l'emplacement actuel vers une classe ou un cluster différent. Si vous appliquez la commande de déplacement sur un sommet particulier, elle mettra à jour toutes les arêtes connectées à ce sommet. Si vous spécifiez un cluster pour déplacer un sommet, il déplace les sommets vers le propriétaire du serveur du cluster cible.
L'instruction suivante est la syntaxe de base de la commande Move Vertex.
MOVE VERTEX <source> TO <destination>
[SET [<field>=<value>]* [,]]
[MERGE <JSON>]
[BATCH <batch-size>]
Voici les détails des options de la syntaxe ci-dessus.
<source>- Définit le sommet que vous souhaitez déplacer. Il accepte l'ID d'enregistrement d'un sommet particulier ou un tableau d'ID d'enregistrement pour les sommets.
<destination>- Définit où vous souhaitez déplacer le sommet. Il prend en charge une classe ou un cluster comme destination.
SET - Définit les valeurs des champs.
MERGE - Définit les valeurs des champs via JSON.
BATCH - Définit la taille du lot.
Note- Cette commande met à jour toutes les arêtes connectées, mais pas les liens. Lors de l'utilisation de l'API Graph, il est recommandé d'utiliser l'arête connectée aux sommets.
Exemple
Essayez les exemples suivants pour apprendre à déplacer des sommets.
Exécutez la requête suivante pour déplacer un seul sommet ayant l'ID d'enregistrement # 11: 2 de sa position actuelle à l'employé de classe.
orientdb> MOVE VERTEX #11:2 TO CLASS:Employee
Si la requête ci-dessus est exécutée avec succès, vous obtiendrez la sortie suivante -
Move vertex command executed with result '[{old:#11:2, new:#13:0}]' in 0.022000 sec(s)
Exécutez la requête suivante pour déplacer l'ensemble de sommets de la classe «Client» vers la classe «Employé».
orientdb> MOVE VERTEX (SELECT FROM Customer) TO CLASS:Employee
Si la requête ci-dessus est exécutée avec succès, vous obtiendrez la sortie suivante.
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 VertexLa commande est utilisée pour supprimer les sommets de la base de données. Lors de la suppression, il vérifie et maintient la cohérence avec les arêtes et supprime toutes les références croisées (avec les arêtes) vers le sommet supprimé.
L'instruction suivante est la syntaxe de base de la commande Delete Vertex.
DELETE VERTEX <vertex> [WHERE <conditions>]
[LIMIT <MaxRecords>>] [BATCH <batch-size>]
Voici les détails des options de la syntaxe ci-dessus.
<vertex> - Définit le sommet que vous souhaitez supprimer, en utilisant sa classe, son ID d'enregistrement ou via une sous-requête.
WHERE - Filtre la condition pour déterminer quels enregistrements la commande supprime.
LIMIT - Définit le nombre maximum d'enregistrements à supprimer.
BATCH - Définit le nombre d'enregistrements que la commande supprime à la fois, vous permettant de diviser les transactions importantes en blocs plus petits pour économiser sur l'utilisation de la mémoire.
Exemple
Essayez la commande suivante pour apprendre à supprimer un ou plusieurs sommets.
Exécutez la commande suivante pour supprimer le sommet '# 14: 1'.
orientdb> DELETE VERTEX #14:1
Si la commande ci-dessus est exécutée avec succès, vous obtiendrez la sortie suivante.
Delete record(s) '1' in 0.005000 sec(s)
Exécutez la commande suivante pour supprimer tous les sommets de la classe 'Customer' marqué avec la propriété 'isSpam'.
orientdb> DELETE VERTEX Customer WHERE isSpam = TRUE
Si la commande ci-dessus est exécutée avec succès, vous obtiendrez la sortie suivante.
Delete record(s) '3' in 0.005000 sec(s)
Dans OrientDB, le concept Edgefonctionne comme une relation entre les sommets à l'aide de certaines propriétés. Les arêtes et les sommets sont les principaux composants d'une base de données de graphes. Il applique le polymorphisme sur les bords. La classe de base pour une arête est E. Lors de l'implémentation des arêtes, si les sommets source ou de destination manquent ou n'existent pas, la transaction sera annulée.
L'instruction suivante est la syntaxe de base de 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>]
Voici les détails des options de la syntaxe ci-dessus.
<class> - Définit le nom de classe du bord.
<cluster> - Définit le cluster dans lequel vous souhaitez stocker l'arête.
JSON - Fournit du contenu JSON à définir comme enregistrement.
RETRY - Définit le nombre de tentatives à tenter en cas de conflit.
WAIT - Définit le délai entre les tentatives en millisecondes.
BATCH - Définit si elle divise la commande en blocs plus petits et la taille des lots.
Exemple
Exécutez la requête suivante pour créer une arête E entre deux sommets # 9: 0 et # 14: 0.
orientdb> CREATE EDGE FROM #11:4 TO #13:2
Si la requête ci-dessus est exécutée avec succès, vous obtiendrez la sortie suivante.
Created edge '[e[#10:0][#9:0->#14:0]]' in 0.012000 sec(s)
Exécutez la requête suivante pour créer un nouveau type d'arête et une arête d'un nouveau type.
orientdb> CREATE CLASS E1 EXTENDS E
orientdb> CREATE EDGE E1 FROM #10:3 TO #11:4
Si la requête ci-dessus est exécutée avec succès, vous obtiendrez la sortie suivante.
Created edge '[e[#10:1][#10:3->#11:4]]' in 0.011000 sec(s)
Update edgeLa commande est utilisée pour mettre à jour les enregistrements Edge dans la base de données actuelle. Cela équivaut à la commande de mise à jour réelle en plus de vérifier et de maintenir la cohérence du graphique avec les sommets, dans le cas où vous mettez à jour leout et in Propriétés.
L'instruction suivante est la syntaxe de base de 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>]
Voici les détails des options de la syntaxe ci-dessus.
<edge>- Définit l'arête que vous souhaitez mettre à jour. Vous pouvez choisir entreClass qui met à jour les arêtes par classe, Cluster qui met à jour les arêtes par cluster, en utilisant le préfixe CLUSTER, ou Record ID que la mise à jour des arêtes par ID d'enregistrement.
SET - Met à jour le champ aux valeurs données.
INCREMENT - Incrémente le champ donné de la valeur.
ADD - Définit un élément à ajouter à une collection de champs.
REMOVE - Définit un élément à supprimer d'une collection de champs.
PUT - Définit une entrée à mettre dans les champs de la carte.
RETURN - Définit l'expression que vous souhaitez renvoyer après l'exécution de la mise à jour.
WHERE - Définit la condition du filtre.
LOCK - Définit comment l'enregistrement se verrouille entre le chargement et les mises à jour.
LIMIT - Définit le nombre maximum d'enregistrements.
Exemple
Prenons un exemple de mise à jour du bord nommé 'adresse' dans la classe de personne en prenant des données de la table d'adresses ayant la zone Id = 001, et le nom de la personne = Krishna.
orientdb> UPDATE EDGE address SET out = (SELECT FROM Address WHERE areaID = 001)
WHERE name = 'krishna'
Si la requête ci-dessus est exécutée avec succès, vous obtiendrez la sortie suivante.
Updated edge '[address[#10:3][#11:3->#14:2]]' in 0.012000 sec(s)
Delete edgeLa commande est utilisée pour supprimer la base de données. Cela équivaut à la commande de suppression, avec l'ajout de la vérification et du maintien de la cohérence avec les sommets en supprimant toutes les références croisées à l'arête des propriétés des sommets «entrant» et «extérieur».
L'instruction suivante est la syntaxe de base de la commande Delete Edge.
DELETE EDGE
( <rid>
|
[<rid> (, <rid>)*]
|
( [ FROM (<rid> | <select_statement> ) ] [ TO ( <rid> | <select_statement> ) ] )
|
[<class>]
(
[WHERE <conditions>]
[LIMIT <MaxRecords>]
[BATCH <batch-size>]
))
Voici les détails des options de la syntaxe ci-dessus.
FROM - Définit le sommet du point de départ de l'arête à supprimer.
To - Définit le sommet du point final de l'arête à supprimer.
WHERE - Définit les conditions de filtrage.
LIMIT - Définit le nombre maximum d'arêtes à supprimer.
BATCH - Définit la taille de bloc pour l'opération.
Exemple
Essayez les exemples suivants pour savoir comment supprimer des arêtes.
Exécutez la requête suivante pour supprimer l'arête entre deux sommets (# 11: 2, # 11: 10). Mais il peut y avoir une chance qu'il existe une ou plusieurs arêtes entre deux sommets. Nous utilisons donc la propriété date pour une fonctionnalité appropriée. Cette requête supprimera les arêtes créées sur '2015-01-15' et ensuite.
orientdb {db = demo}> DELETE EDGE FROM #11:2 TO #11:10 WHERE date >= "2012-01-15"
Si la requête ci-dessus est exécutée avec succès, vous obtiendrez la sortie suivante.
Delete record(s) '2' in 0.00200 sec(s)
Exécutez la requête suivante pour supprimer les arêtes en commençant par le sommet '# 11: 5' jusqu'au sommet '# 11: 10' et qui sont liées à 'class = Customer'.
orientdb {db = demo}> DELETE EDGE FROM #11:5 TO #11:10 WHERE @class = 'Customer'
Si la requête ci-dessus est exécutée avec succès, vous obtiendrez la sortie suivante.
Delete record(s) '2' in 0.00200 sec(s)
Ce chapitre explique la référence complète des différents types de fonctions dans OrientDB. Le tableau suivant définit la liste des fonctions, qui sont classées selon leur fonctionnalité.
Fonctions graphiques
Sr.No. | Nom et description de la fonction |
---|---|
1 | Out(): Obtient les sommets sortants adjacents à partir de l'enregistrement actuel en tant que Vertex. Syntax - sortie ([<label-1>] [, <label-n>] *) |
2 | In(): Obtient les sommets entrants adjacents à partir de l'enregistrement actuel en tant que Vertex. Syntax - dans ([<label-1>] [, <label-n>] *) |
3 | Both(): Obtient les sommets adjacents sortants et entrants à partir de l'enregistrement actuel en tant que Vertex. Syntax - les deux ([<label1>] [, <label-n>] *) |
4 | outE(): Obtient les arêtes sortantes adjacentes à partir de l'enregistrement actuel en tant que Vertex. Syntax - outE ([<label1>] [, <label-n>] *) |
5 | inE(): Obtient les arêtes entrantes adjacentes à partir de l'enregistrement actuel en tant que Vertex. Syntax - inE ([<label1>] [, <label-n>] *) |
6 | bothE(): Obtient les bords sortants et entrants adjacents à partir de l'enregistrement actuel en tant que Vertex. Syntax - bothE ([<label1>] [, <label-n>] *) |
sept | outV(): Obtient les sommets sortants à partir de l'enregistrement actuel en tant que Edge. Syntax - outV () |
8 | inV(): Obtenez les sommets entrants de l'enregistrement actuel en tant que Edge. Syntax - inV () |
9 | traversedElement(): Renvoie le ou les éléments traversés dans les commandes Traverse. Syntax - traversedElement (<index> [, <items>]) |
dix | traversedVertex(): Renvoie le ou les sommets traversés dans les commandes Traverse. Syntax - traversedVertex (<index> [, <items>]) |
11 | traversedEdge(): Renvoie le (s) bord (s) traversé (s) dans les commandes Traverse. Syntax - traversedEdge (<index> [, <items>]) |
12 | shortestPath(): Renvoie le chemin le plus court entre deux sommets. La direction peut être OUT (par défaut), IN ou BOTH. Synatx - shortestPath (<sourceVertex>, <destinationVertex> [, <direction> [, <edgeClassName>]]) |
13 | dijkstra(): Renvoie le chemin le moins cher entre deux sommets à l'aide de l'algorithme de Dijkstra. Syntax - dijkstra (<sourceVertex>, <destinationVertex>, <weightEdgeFieldName> [, <direction>]) |
Essayez quelques fonctions graphiques avec les requêtes suivantes.
Exécutez la requête suivante pour obtenir tous les sommets sortants de tous les sommets de véhicule.
orientdb {db = demo}>SELECT out() from Vehicle
Si la requête ci-dessus est exécutée avec succès, vous obtiendrez la sortie suivante.
---+----------+---------
# | @class | out
---+----------+---------
0 | Vehicle | #11:2
1 | Vehicle | #13:1
2 | Vehicle | #13:4
---+----------+---------
Exécutez la requête suivante pour obtenir les sommets entrants et sortants du sommet # 11: 3.
orientdb {db = demo}>SELECT both() FROM #11:3
Si la requête ci-dessus est exécutée avec succès, vous obtiendrez la sortie suivante.
---+----------+--------+-------
# | @class | out | in
---+----------+--------+-------
0 | Vehicle | #13:2 | #10:2
---+----------+-------+-------
Fonctions mathématiques
Sr.No. | Nom et description de la fonction |
---|---|
1 | eval(): Évalue l'expression entre guillemets (ou guillemets doubles). Syntax - eval ('<expression>') |
2 | min(): Renvoie la valeur minimale. S'il est invoqué avec plus d'un paramètre, il renvoie la valeur d'argument minimale entre tous les arguments. Syntax - min (<champ> [, <champ-n>] *) |
3 | max(): Renvoie la valeur maximale. Si elle est appelée avec plus d'un paramètre, renvoie la valeur maximale entre tous les arguments. Syntax - max (<champ> [, <champ-n>] *) |
4 | sum() Renvoie la somme de toutes les valeurs renvoyées. Syntax - somme (<champ>) |
5 | abs(): Renvoie la valeur absolue. Il fonctionne avec Integer, Long, Short, Double, Float, BigInteger, BigDecimal, null. Syntax - abs (<champ>) |
6 | avg(): Renvoie la valeur moyenne. Syntax - moy (<champ>) |
sept | count(): Compte l'enregistrement qui correspond à la condition de requête. Si * n'est pas utilisé comme champ, alors l'enregistrement ne sera compté que si le contenu n'est pas nul. Syntax - compter (<champ>) |
8 | mode(): Renvoie la valeur qui se produit avec la fréquence la plus élevée. Les valeurs nulles sont ignorées dans le calcul. Syntax - mode (<champ>) |
9 | median(): Renvoie la valeur du milieu ou une valeur interpolée qui représente la valeur du milieu une fois les valeurs triées. Les valeurs nulles sont ignorées dans le calcul. Syntax - médiane (<champ>) |
dix | percentile(): Renvoie le nième centile. Null est ignoré dans le calcul. Syntax - centile (<field> [, <quantile-n>] *) |
11 | variance() Renvoie la variance moyenne: la moyenne de la différence quadratique par rapport à la moyenne.
Syntax - variance (<champ>) |
12 | stddev() Renvoie l'écart type: la mesure de la répartition des valeurs. Les valeurs nulles sont ignorées dans le calcul. Syntax - stddev (<champ>) |
Essayez quelques fonctions mathématiques en utilisant les requêtes suivantes.
Exécutez la requête suivante pour obtenir la somme des salaires de tous les employés.
orientdb {db = demo}>SELECT SUM(salary) FROM Employee
Si la requête ci-dessus est exécutée avec succès, vous obtiendrez la sortie suivante.
---+----------+---------
# | @CLASS | sum
---+----------+---------
0 | null | 150000
---+----------+---------
Exécutez la requête suivante pour obtenir le salaire moyen de tous les employés.
orientdb {db = demo}>SELECT avg(salary) FROM Employee
Si la requête ci-dessus est exécutée avec succès, vous obtiendrez la sortie suivante.
---+----------+---------
# | @CLASS | avg
---+----------+---------
0 | null | 25
---+----------+---------
Fonctions des collections
Sr.No. | Nom et description de la fonction |
---|---|
1 | set(): Ajoute une valeur à un ensemble. Si la valeur est une collection, elle est fusionnée avec l'ensemble, sinon <valeur> est ajoutée. Syntax - définir (<champ>) |
2 | map(): Ajoute une valeur à une carte la première fois que la carte est créée. Si <valeur> est une carte, alors elle est fusionnée avec la carte, sinon la paire <key> et <value> est ajoutée à la carte en tant que nouvelle entrée. Syntax - carte (<key>, <valeur>) |
3 | ist(): Ajoute une valeur à lister la première fois que la liste est créée. Si <valeur> est une collection, alors elle est fusionnée avec la liste, sinon <valeur> est ajoutée à la liste. Syntax - liste (<champ>) |
4 | difference(): Fonctionne comme agrégé ou en ligne. Si un seul argument est passé, l'agrégation, sinon, s'exécute et renvoie la DIFFÉRENCE entre les collections reçues en tant que paramètres. Syntax - différence (<field> [, <field-n>] *) |
5 | first(): Récupère uniquement le premier élément des champs à valeurs multiples (tableaux, collections et cartes). Pour les types non multi-valeurs, renvoie simplement la valeur. Syntax - premier (<champ>) |
6 | intersect(): Fonctionne comme agrégé ou en ligne. Si un seul argument est passé, alors agrège, sinon exécute et retourne, l'INTERACTION des collections reçues en tant que paramètres. Syntax - intersecter (<field> [, <field-n>] *) |
sept | distinct(): Récupère uniquement les entrées de données uniques en fonction du champ que vous avez spécifié comme argument. La principale différence par rapport à SQL DISTINCT standard est qu'avec OrientDB, une fonction entre parenthèses et un seul champ peut être spécifié. Syntax - distinct (<champ>) |
8 | expand(): Cette fonction a deux significations -
Syntax - développer (<champ>) |
9 | unionall(): Fonctionne comme agrégé ou en ligne. Si un seul argument est passé, alors agrège, sinon exécute et renvoie une UNION de toutes les collections reçues en tant que paramètres. Fonctionne également sans valeurs de collection. Syntax - unionall (<field> [, <field-n>] *) |
dix | flatten(): Extrait la collection dans le champ et l'utilise comme résultat. Il est obsolète, utilisez plutôt expand (). Syntax - aplatir (<champ>) |
11 | last(): Récupère uniquement le dernier élément des champs à valeurs multiples (tableaux, collections et cartes). Pour les types non multi-valeurs, renvoie simplement la valeur. Syntax - dernier (<champ>) |
12 | symmetricDifference(): Fonctionne comme agrégé ou en ligne. Si un seul argument est passé, alors agrège, sinon exécute et retourne, la DIFFÉRENCE SYMÉTRIQUE entre les collections reçues en tant que paramètres. Syntax - symétriqueDifférence (<champ> [, <champ-n>] *) |
Essayez certaines fonctions de collecte en utilisant les requêtes suivantes.
Exécutez la requête suivante pour obtenir un ensemble d'enseignants, enseignant la 9e classe.
orientdb {db = demo}>SELECT ID, set(teacher.id) AS teacherID from classess where class_id = 9
Si la requête ci-dessus est exécutée avec succès, vous obtiendrez la sortie suivante.
---+----------+--------+--------------------------
# | @CLASS | id | TeacherID
---+----------+--------+--------------------------
0 | null | 9 | 1201, 1202, 1205, 1208
---+----------+-------+---------------------------
Fonctions diverses
Sr.No. | Nom et description de la fonction |
---|---|
1 | date(): Renvoie une date mettant en forme une chaîne. <date-as-string> est la date au format chaîne, et <format> est le format de date suivant ces règles. Syntax - date (<date-as-string> [<format>] [, <timezone>]) |
2 | sysdate(): Renvoie la date et l'heure actuelles. Syntax - sysdate ([<format>] [, <timezone>]) |
3 | format(): Formate une valeur à l'aide des conventions String.format (). Syntax - format (<format> [, <arg1>] (, <arg-n>] *. Md) |
4 | distance(): Renvoie la distance entre deux points du globe à l'aide de l'algorithme Haversine. Les coordonnées doivent être des degrés. Syntax - distance (<x-field>, <y-field>, <x-value>, <y-value>) |
5 | ifnull(): Renvoie le champ / la valeur transmis (ou le paramètre facultatif return_value_if_not_null). Si le champ / la valeur n'est pas nul, il renvoie return_value_if_null. Syntax - ifnull (<champ | valeur>, <valeur_retour_if_null> [, <valeur_retour_if_not_null>] (, <champ & .md # 124; valeur>] *) |
6 | coalesce(): Renvoie le premier paramètre champ / valeur non nul. Si aucun champ / valeur n'est nul, renvoie null. Syntax - coalesce (<champ | valeur> [, <champ-n | valeur-n>] *) |
sept | uuid(): Génère un UUID sous la forme d'une valeur de 128 bits à l'aide de la variante Leach-Salz. Syntax - uuid () |
8 | if(): Évalue une condition (premiers paramètres) et renvoie le deuxième paramètre si la condition est vraie, le troisième sinon. Syntax - si (<expression>, <résultat- si- vrai>, <résultat- si- faux>) |
Essayez quelques fonctions diverses en utilisant les requêtes suivantes.
Exécutez la requête suivante pour savoir comment exécuter l'expression if.
orientdb {db = demo}> SELECT if(eval("name = 'satish'"), "My name is satish",
"My name is not satish") FROM Employee
Si la requête ci-dessus est exécutée avec succès, vous obtiendrez la sortie suivante.
----+--------+-----------------------
# |@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
----+--------+------------------------
Exécutez la requête suivante pour obtenir la date système.
orientdb {db = demo}> SELECT SYSDATE() FROM Employee
Si la requête ci-dessus est exécutée avec succès, vous obtiendrez la sortie suivante.
----+--------+-----------------------
# |@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
----+--------+------------------------
En utilisant cette fonction à fond, vous pouvez facilement manipuler les données OrientDB.
Sequencesest un concept utilisé dans le mécanisme d'incrémentation automatique et il est introduit dans OrientDB v2.2. Dans la terminologie des bases de données, la séquence est une structure qui gère le champ compteur. Les séquences simplement dites sont principalement utilisées lorsque vous avez besoin d'un nombre qui s'incrémente toujours. Il prend en charge deux types -
ORDERED - Chaque fois que le pointeur appelle la méthode .next qui renvoie une nouvelle valeur.
CACHED- La séquence mettra en cache «N» éléments sur chaque nœud. Pour appeler chaque élément que nous utilisons.next(), qui est préférable lorsque le cache contient plusieurs éléments.
Créer une séquence
La séquence est généralement utilisée pour incrémenter automatiquement la valeur d'identifiant d'une personne. Comme les autres concepts SQL d'OrientDB, il effectue également des opérations similaires à celles de la séquence dans le SGBDR.
L'instruction suivante est la syntaxe de base pour créer des séquences.
CREATE SEQUENCE <sequence> TYPE <CACHED|ORDERED> [START <start>]
[INCREMENT <increment>] [CACHE <cache>]
Voici les détails des options de la syntaxe ci-dessus.
<Sequence> - Nom local de la séquence.
TYPE - Définit le type de séquence ORDERED ou CACHED.
START - Définit la valeur initiale.
INCREMENT - Définit l'incrément pour chaque appel de méthode .next.
CACHE - Définit le nombre de valeur à pré-mettre en cache, dans le cas où vous avez utilisé pour mettre en cache le type de séquence.
Créons une séquence nommée 'seqid' qui commence par le numéro 1201. Essayez les requêtes suivantes pour implémenter cet exemple avec sequence.
CREATE SEQUENCE seqid START 1201
Si la requête ci-dessus est exécutée avec succès, vous obtiendrez la sortie suivante.
Sequence created successfully
Essayez la requête suivante pour utiliser la séquence 'seqid' pour insérer la valeur d'id de la table Account.
INSERT INTO Account SET id = sequence('seqid').next()
Si la requête ci-dessus est exécutée avec succès, vous obtiendrez la sortie suivante.
Insert 1 record(s) in 0.001000 sec(s)
Modifier la séquence
Modifier la séquence est une commande utilisée pour modifier les propriétés d'une séquence. Il modifiera toutes les options de séquence sauf le type de séquence.
L'instruction suivante est la syntaxe de base pour modifier la séquence.
ALTER SEQUENCE <sequence> [START <start-point>]
[INCREMENT <increment>] [CACHE <cache>]
Voici les détails des options de la syntaxe ci-dessus.
<Sequence> - Définit la séquence que vous souhaitez modifier.
START - Définit la valeur initiale.
INCREMENT - Définit l'incrément pour chaque appel de méthode .next.
CACHE - Définit le nombre de valeurs à pré-mettre en cache dans l'événement que vous avez utilisé pour mettre en cache le type de séquence.
Essayez la requête suivante pour modifier la valeur de départ de «1201 à 1000» d'une séquence nommée seqid.
ALTER SEQUENCE seqid START 1000
Si la requête ci-dessus est exécutée avec succès, vous obtiendrez la sortie suivante.
Altered sequence successfully
Séquence de dépôt
Drop sequence est une commande utilisée pour supprimer une séquence.
L'instruction suivante est la syntaxe de base pour supprimer une séquence.
DROP SEQUENCE <sequence>
Où <Sequence> définit la séquence que vous souhaitez supprimer.
Essayez la requête suivante pour supprimer une séquence nommée «seqid».
DROP SEQUENCE seqid
Si la requête ci-dessus est exécutée avec succès, vous obtiendrez la sortie suivante.
Sequence dropped successfully
Index est un pointeur qui pointe vers un emplacement de données dans la base de données. Indexingest un concept utilisé pour localiser rapidement les données sans avoir à rechercher chaque enregistrement dans une base de données. OrientDB prend en charge quatre algorithmes d'index et plusieurs types dans chacun.
Les quatre types d'index sont -
Index SB-Tree
Il fournit un bon mélange de fonctionnalités disponibles à partir d'autres types d'index. Mieux vaut l'utiliser pour une utilité générale. Il est durable, transactionnel et prend en charge les requêtes de plage. C'est le type d'index par défaut. Les différents types de plugins qui prennent en charge cet algorithme sont -
UNIQUE- Ces index n'autorisent pas les clés en double. Pour les index composites, cela fait référence à l'unicité des clés composites.
NOTUNIQUE - Ces index permettent la duplication des clés.
FULLTEXT- Ces index sont basés sur un seul mot de texte. Vous pouvez les utiliser dans les requêtes via leCONTAINSTEXT opérateur.
DICTIONARY - Ces index sont similaires à ceux qui utilisent UNIQUE, mais dans le cas de clés dupliquées, ils remplacent l'enregistrement existant par le nouvel enregistrement.
Index de hachage
Il fonctionne plus rapidement et est très léger dans l'utilisation du disque. Il est durable, transactionnel, mais ne prend pas en charge les requêtes de plage. Il fonctionne comme HASHMAP, ce qui accélère les recherches ponctuelles et consomme moins de ressources que les autres types d'index. Les différents types de plugins qui prennent en charge cet algorithme sont -
UNIQUE_HASH_INDEX- Ces index n'autorisent pas les clés en double. Pour les index composites, cela fait référence à l'unicité des clés composites.
NOTUNIQUE_HASH_INDEX - Ces index permettent la duplication des clés.
FULLTEXT_HASH_INDEX- Ces index sont basés sur un seul mot de texte. Vous pouvez les utiliser dans les requêtes via l'opérateur CONTAINSTEXT.
DICTIONARY_HASH_INDEX - Ces index sont similaires à ceux qui utilisent UNIQUE_HASH_INDEX, mais en cas de clés en double, ils remplacent l'enregistrement existant par le nouvel enregistrement.
Index de texte intégral Lucene
Il fournit de bons index de texte intégral, mais ne peut pas être utilisé pour indexer d'autres types. Il est durable, transactionnel et prend en charge les requêtes de plage.
Indice spatial Lucene
Il fournit de bons index spatiaux, mais ne peut pas être utilisé pour indexer d'autres types. Il est durable, transactionnel et prend en charge les requêtes de plage.
Créer des index
Create index est une commande pour créer un index sur un schéma particulier.
L'instruction suivante est la syntaxe de base pour créer un index.
CREATE INDEX <name> [ON <class-name> (prop-names)] <type> [<key-type>]
[METADATA {<metadata>}]
Voici les détails des options de la syntaxe ci-dessus.
<name>- Définit le nom logique de l'index. Vous pouvez également utiliser la notation <class.property> pour créer un index automatique lié à une propriété de schéma. <classe> utilise la classe du schéma et <property> utilise la propriété créée dans la classe.
<class-name>- Fournit le nom de la classe que vous créez l'index automatique à indexer. Cette classe doit exister dans la base de données.
<prop-names>- Fournit la liste des propriétés que vous souhaitez que l'index automatique indexe. Ces propriétés doivent déjà exister dans le schéma.
<type> - Fournit l'algorithme et le type d'index que vous souhaitez créer.
<key-type> - Fournit le type de clé facultatif avec des index automatiques.
<metadata> - Fournit la représentation JSON.
Exemple
Essayez la requête suivante pour créer un index automatique lié à la propriété 'ID' de l'utilisateur sales_user.
orientdb> CREATE INDEX indexforID ON sales_user (id) UNIQUE
Si la requête ci-dessus est exécutée avec succès, vous obtiendrez la sortie suivante.
Creating index...
Index created successfully with 4 entries in 0.021000 sec(s)
Interroger les index
Vous pouvez utiliser la requête de sélection pour obtenir les enregistrements dans l'index.
Essayez la requête suivante pour récupérer les clés de l'index nommé «indexforId».
SELECT FROM INDEX:indexforId
Si la requête ci-dessus est exécutée avec succès, vous obtiendrez la sortie suivante.
----+------+----+-----
# |@CLASS|key |rid
----+------+----+-----
0 |null |1 |#11:7
1 |null |2 |#11:6
2 |null |3 |#11:5
3 |null |4 |#11:8
----+------+----+-----
Index de suppression
Si vous souhaitez supprimer un index particulier, vous pouvez utiliser cette commande. Cette opération ne supprime pas les enregistrements liés.
L'instruction suivante est la syntaxe de base pour supprimer un index.
DROP INDEX <name>
Où <name> fournit le nom de l'index que vous souhaitez supprimer.
Essayez la requête suivante pour supprimer un index nommé 'ID' de l'utilisateur sales_user.
DROP INDEX sales_users.Id
Si la requête ci-dessus est exécutée avec succès, vous obtiendrez la sortie suivante.
Index dropped successfully
Comme le SGBDR, OrientDB prend en charge les propriétés ACID des transactions. UNEtransactioncomprend une unité de travail effectuée dans un système de gestion de base de données. Il existe deux raisons principales pour maintenir les transactions dans un environnement de base de données.
Pour permettre une récupération simultanée après des pannes et maintenir une base de données cohérente même en cas de panne du système.
Pour fournir une isolation entre les programmes accédant simultanément à une base de données.
Par défaut, la transaction de base de données doit suivre les propriétés ACID telles que les propriétés Atomic, Consistent, Isolated et Durable. Mais OrientDB est une base de données compatible ACID, ce qui signifie qu'elle ne contredit ni ne nie le concept ACID, mais qu'elle change sa perception lors de la gestion de la base de données NoSQL. Regardez comment les propriétés ACID fonctionnent avec la base de données NoSQL.
Atomic - Lorsque vous faites quelque chose pour changer la base de données, le changement devrait fonctionner ou échouer dans son ensemble.
Consistent - La base de données doit rester cohérente.
Isolated - Si d'autres exécutions de transaction sont exécutées en même temps, l'utilisateur ne pourra pas voir les enregistrements en exécution simultanée.
Durable - Si le système tombe en panne (matériel ou logiciel), la base de données elle-même devrait pouvoir effectuer une sauvegarde.
La transaction de base de données peut être réalisée à l'aide des commandes Commit et Rollback.
Commettre
Valider signifie fermer la transaction en enregistrant toutes les modifications dans la base de données. La restauration signifie récupérer l'état de la base de données au point où vous avez ouvert la transaction.
L'instruction suivante est la syntaxe de base de la commande de base de données COMMIT.
COMMIT
Note - Vous ne pouvez utiliser cette commande qu'après vous être connecté à une base de données particulière et après avoir commencé la transaction.
Exemple
Dans cet exemple, nous utiliserons la même base de données nommée «demo» que nous avons créée dans un chapitre précédent de ce tutoriel. Nous verrons le fonctionnement de la transaction de validation et stockerons un enregistrement à l'aide de transactions.
Vous devez d'abord démarrer la transaction à l'aide de la commande BEGIN suivante.
orientdb {db = demo}> BEGIN
Insérez un enregistrement dans une table d'employés avec les valeurs id = 12 et name = satish.P à l'aide de la commande suivante.
orientdb> INSERT INTO employee (id, name) VALUES (12, 'satish.P')
Vous pouvez utiliser la commande suivante pour valider la transaction.
orientdb> commit
Si cette transaction est validée avec succès, vous obtiendrez la sortie suivante.
Transaction 2 has been committed in 4ms
Retour en arriere
La restauration signifie la récupération de l'état de la base de données au point où vous avez ouvert la transaction.
L'instruction suivante est la syntaxe de base de la commande de base de données ROLLBACK.
ROLLBACK
Note - Vous ne pouvez utiliser cette commande qu'après vous être connecté à une base de données particulière et après avoir commencé la transaction.
Exemple
Dans cet exemple, nous utiliserons la même base de données nommée «demo» que nous avons créée dans un chapitre précédent du didacticiel. Nous verrons l'opération de la transaction d'annulation et stockerons un enregistrement à l'aide de transactions.
Vous devez d'abord démarrer la transaction à l'aide de la commande BEGIN suivante.
orientdb {db = demo}> BEGIN
Insérez un enregistrement dans une table d'employés avec les valeurs id = 12 et name = satish.P à l'aide de la commande suivante.
orientdb> INSERT INTO employee (id, name) VALUES (12, 'satish.P')
Vous pouvez utiliser la commande suivante pour récupérer les enregistrements de l'employé de la table.
orientdb> SELECT FROM employee WHERE name LIKE '%.P'
Si cette commande est exécutée avec succès, vous obtiendrez la sortie suivante.
---+-------+--------------------
# | ID | name
---+-------+--------------------
0 | 12 | satish.P
---+-------+--------------------
1 item(s) found. Query executed in 0.076 sec(s).
Vous pouvez utiliser la commande suivante pour annuler cette transaction.
orientdb> ROLLBACK
Vérifiez à nouveau la requête de sélection pour récupérer le même enregistrement de la table Employee.
orientdb> SELECT FROM employee WHERE name LIKE '%.P'
Si la restauration est exécutée avec succès, vous obtiendrez 0 enregistrement trouvé dans la sortie.
0 item(s) found. Query executed in 0.037 sec(s).
OrientDB Hooksne sont que des déclencheurs dans la terminologie de la base de données qui activent des événements internes avant et après chaque opération CRUD dans les applications utilisateur. Vous pouvez utiliser des hooks pour écrire des règles de validation personnalisées, pour appliquer la sécurité ou pour organiser des événements externes tels que la réplication sur un SGBD relationnel.
OrientDB prend en charge deux types de crochets -
Dynamic Hook - Déclencheurs, qui peuvent être construits au niveau de la classe et / ou au niveau du document.
Java (Native) Hook - Déclencheurs, qui peuvent être construits à l'aide de classes Java.
Crochets dynamiques
Les hooks dynamiques sont plus flexibles que les hooks Java, car ils peuvent être modifiés à l'exécution et peuvent s'exécuter par document si nécessaire, mais sont plus lents que les hooks Java.
Pour exécuter des hooks sur vos documents, autorisez d'abord vos classes à s'étendre OTriggeredclasse de base. Plus tard, définissez une propriété personnalisée pour l'événement intéressé. Voici les événements disponibles.
onBeforeCreate - Appelé before créer un nouveau document.
onAfterCreate - Appelé after créer un nouveau document.
onBeforeRead - Appelé before lire un document.
onAfterRead - Appelé after lire un document.
onBeforeUpdate - Appelé before mettre à jour un document.
onAfterUpdate - Appelé after mettre à jour un document.
onBeforeDelete - Appelé before supprimer un document.
onAfterDelete - Appelé after supprimer un document.
Les Hooks dynamiques peuvent appeler -
Fonctions, écrites en SQL, Javascript ou tout autre langage pris en charge par OrientDB et JVM.
Méthodes statiques Java.
Crochets de niveau de classe
Les hooks de niveau classe sont définis pour tous les documents liés à une classe. Voici un exemple de configuration d'un hook qui agit au niveau de la classe sur les documents de facturation.
CREATE CLASS Invoice EXTENDS OTriggered
ALTER CLASS Invoice CUSTOM onAfterCreate = invoiceCreated
Créons la fonction invoiceCreated en Javascript qui imprime dans la console du serveur le numéro de facture créé.
CREATE FUNCTION invoiceCreated "print('\\nInvoice created: ' + doc.field ('number'));"
LANGUAGE Javascript
Maintenant, essayez le crochet en créant un nouveau Invoice document.
INSERT INTO Invoice CONTENT {number: 100, notes: 'This is a test}
Si cette commande est exécutée avec succès, vous obtiendrez la sortie suivante.
Invoice created: 100
Crochet au niveau du document
Vous ne pouvez définir une action spéciale que sur un ou plusieurs documents. Pour ce faire, autorisez votre classe à s'étendreOTriggered classe.
Par exemple, exécutons un trigger, en tant que fonction Javascript, sur une classe Profile existante, pour tous les documents avec la propriété account = 'Premium'. Le déclencheur sera appelé pour empêcher la suppression de documents.
ALTER CLASS Profile SUPERCLASS OTriggered UPDATE Profile
SET onBeforeDelete = 'preventDeletion' WHERE account = 'Premium'
Créons le preventDeletion() Fonction Javascript.
CREATE FUNCTION preventDeletion "throw new java.lang.RuntimeException('Cannot
delete Premium profile ' + doc)" LANGUAGE Javascript
Et puis testez le hook en essayant de supprimer un compte «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
Crochets JAVA
Un cas d'utilisation courant des Hooks OrientDB (déclencheurs) est de gérer les dates de création et de mise à jour pour une ou toutes les classes. Par exemple, vous pouvez définir unCreatedDate champ chaque fois qu'un enregistrement est créé et définir un UpdatedDate chaque fois qu'un enregistrement est mis à jour, et faites-le de manière à implémenter la logique une fois au niveau de la couche de base de données et à ne plus jamais avoir à vous en soucier au niveau de la couche application.
Avant de créer, vous devrez télécharger orientdb-core.jarfichier en visitant le lien suivant télécharger OrientDB core . Et plus tard, copiez ce fichier jar dans le dossier où vous souhaitez stocker le fichier source Java.
Créer un fichier Hook
Créez un fichier Java nommé HookTest.java, qui testera le mécanisme Hook en utilisant le langage 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;
}
}
L'exemple de code ci-dessus imprime le commentaire approprié chaque fois que vous créez ou mettez à jour un enregistrement de cette classe.
Ajoutons un autre fichier hook setCreatedUpdatedDates.java comme suit -
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;
}
}
}
Ce que le code ci-dessus fait est de rechercher toute classe commençant par les lettres 'r' ou 't'et définit CreatedDate et UpdatedDate lorsque l'enregistrement est créé et définit uniquement UpdatedDate chaque fois que l'enregistrement est mis à jour.
Compiler Java Hooks
Compilez le code Java à l'aide de la commande suivante. Note: Conservez le fichier jar téléchargé et ces fichiers Java dans le même dossier.
$ jar cf hooks-1.0-SNAPSHOT.jar *.java
Déplacer le code compilé là où le serveur OrientDB peut le trouver
Vous devez copier le fichier .jar terminé dans le répertoire où votre serveur OrientDB les recherchera. Cela signifie le './libLe dossier sous votre répertoire racine du serveur OrientDB ressemblera à ceci -
$ cp hooks-1.0-SNAPSHOT.jar "$ORIENTDB_HOME/lib"
Activer le crochet de test dans le fichier de configuration du serveur OrientDB
Éditer $ORIENTDB_HOME/config/orientdb-server-config.xml et ajoutez la section suivante vers la fin du fichier.
<hooks>
<hook class = "HookTest" position = "REGULAR"/>
</hooks>
...
</orient-server>
Redémarrez le serveur OrientDB
Une fois que vous redémarrez OrientDB Server, le hook que vous avez défini dans orientdb-server-config.xmlest maintenant actif. Lancez une console OrientDB, connectez-la à votre base de données et exécutez la commande suivante -
INSERT INTO V SET ID = 1;
Si cette commande est exécutée avec succès, vous obtiendrez la sortie suivante.
Ran create hook
Exécutez maintenant la commande suivante -
UPDATE V SET ID = 2 WHERE ID = 1;
Si cette commande est exécutée avec succès, vous obtiendrez la sortie suivante.
Ran update hook
Activer Real Hook dans le fichier de configuration du serveur OrientDB
Éditer $ORIENTDB_HOME/config/orientdb-server-config.xml et changez la section des crochets comme suit -
<hooks>
<hook class="setCreatedUpdatedDates" position="REGULAR"/>
</hooks>
...
</orient-server>
Redémarrez le serveur OrientDB
Créez une nouvelle classe commençant par la lettre 'r' ou 't'-
CREATE CLASS tTest EXTENDS V;
Maintenant, insérez un enregistrement -
INSERT INTO tTest SET ID = 1
SELECT FROM tTest
Si cette commande est exécutée avec succès, vous obtiendrez la sortie suivante.
----+-----+------+----+-----------+-----------
# |@RID |@CLASS|ID |CreatedDate|UpdatedDate
----+-----+------+----+-----------+-----------
0 |#19:0|tTest |1 |1427597275 |1427597275
----+-----+------+----+-----------+-----------
Même si vous n'avez pas spécifié de valeurs à définir CreatedDate et UpdatedDate, OrientDB a défini ces champs automatiquement pour vous.
Ensuite, vous devez mettre à jour l'enregistrement à l'aide de la commande suivante -
UPDATE tTest SET ID = 2 WHERE ID = 1;
SELECT FROM tTest;
Si cette commande est exécutée avec succès, vous obtiendrez la sortie suivante.
----+-----+------+----+-----------+-----------
# |@RID |@CLASS|ID |CreatedDate|UpdatedDate
----+-----+------+----+-----------+-----------
0 |#19:0|tTest |2 |1427597275 |1427597306
----+-----+------+----+-----------+-----------
Vous pouvez voir que OrientDB a changé le UpdatedDate mais a laissé le CreatedDate restent inchangés.
OrientDB Java Hooks peut être un outil extrêmement précieux pour aider à automatiser le travail que vous auriez autrement à faire dans le code d'application. Étant donné que de nombreux administrateurs de base de données ne sont pas toujours des experts Java, nous espérons que les informations contenues dans ce didacticiel vous donneront une longueur d'avance et vous permettront de vous sentir à l'aise avec la technologie, vous permettant de créer avec succès des déclencheurs de base de données en cas de besoin.
Cachingest un concept qui créera une copie de la structure de table de la base de données offrant un environnement confortable pour les applications utilisateur. OrientDB a plusieurs mécanismes de mise en cache à différents niveaux.
L'illustration suivante donne une idée de ce qu'est la mise en cache.
Dans l'illustration ci-dessus DB1, DB2, DB3 sont les trois instances de base de données différentes utilisées dans une application.
Level-1 le cache est un Local cachequi stocke toutes les entités connues par une session spécifique. Si vous avez trois transactions dans cette session, elle contiendra toutes les entités utilisées par les trois transactions. Ce cache est effacé lorsque vous fermez la session ou lorsque vous exécutez la méthode «clear». Cela réduit la charge des opérations d'E / S entre l'application et la base de données et augmente à son tour les performances.
Level-2 le cache est un Real cachequi fonctionne en utilisant un fournisseur tiers. Vous pouvez avoir un contrôle total sur le contenu du cache, c'est-à-dire que vous serez en mesure de spécifier quelles entrées doivent être supprimées, lesquelles doivent être stockées plus longtemps et ainsi de suite. Il s'agit d'un cache partagé complet entre plusieurs threads.
Storage model n'est rien d'autre qu'un périphérique de stockage qui est un disque, une mémoire ou un serveur distant.
Comment fonctionne le cache dans OrientDB?
La mise en cache OrientDB fournit différentes méthodologies dans différents environnements. La mise en cache est principalement utilisée pour des transactions de base de données plus rapides, réduisant le temps de traitement d'une transaction et augmentant les performances. Les organigrammes suivants montrent comment la mise en cache fonctionne en mode local et en mode client-serveur.
Mode local (base de données intégrée)
L'organigramme suivant vous indique comment l'enregistrement se situe entre le stockage et l'application utilisée en mode local, c'est-à-dire lorsque votre serveur de base de données se trouve dans votre hôte local.
Lorsque l'application cliente demande un enregistrement, OrientDB vérifie les éléments suivants -
Si une transaction a commencé, il recherche à l'intérieur de la transaction les enregistrements modifiés et les renvoie si elle est trouvée.
Si le cache local est activé et contient l'enregistrement demandé, le renvoie.
Si, à ce stade, l'enregistrement n'est pas dans le cache, il le demande au stockage (disque, mémoire).
Mode client-serveur (base de données distante)
L'organigramme suivant vous indique comment l'enregistrement se situe entre le stockage et l'application utilisée en mode client-serveur, c'est-à-dire lorsque votre serveur de base de données est à distance.
Lorsque l'application cliente demande un enregistrement, OrientDB vérifie les éléments suivants -
Si une transaction a commencé, il recherche à l'intérieur de la transaction les enregistrements modifiés et les renvoie si elle est trouvée.
Si le cache local est activé et contient l'enregistrement demandé, le renvoie.
À ce stade, si l'enregistrement n'est pas dans le cache, le demande au serveur via un appel TCP / IP.
Dans le serveur, si le cache local est activé et contient l'enregistrement demandé, il le renvoie.
À ce stade, l'enregistrement n'est toujours pas mis en cache dans le serveur, puis le demande au stockage (disque, mémoire).
OrientDB utilise le framework Java Logging fourni avec Java Virtual Machine. Le format de journal par défaut d'OrientDB est géré parOLogFormatter classe.
L'instruction suivante est la syntaxe de base de la commande de journalisation.
<date> <level> <message> [<requester>]
Voici les détails des options de la syntaxe ci-dessus.
<date> - Il s'agit de la date du journal au format suivant: aaaa-MM-jj HH: mm: ss: SSS.
<level> - C'est le niveau de journalisation en sortie de 5 caractères.
<message> - C'est le texte du journal, il peut être de n'importe quelle taille.
[<class>] - C'est la classe Java qui est journalisée (facultatif).
Les niveaux pris en charge sont ceux contenus dans la classe JRE java.util.logging.Level. Ils sont -
- SEVERE (valeur la plus élevée)
- WARNING
- INFO
- CONFIG
- FINE
- FINER
- FINEST (valeur la plus basse)
Par défaut, deux enregistreurs sont installés -
Console, comme sortie de l'invite shell / de commande qui démarre l'application / le serveur. Peut être modifié en définissant la variable «log.console.level».
File, comme sortie vers les fichiers journaux. Peut être modifié en définissant le 'log.file.level'.
Configurer la journalisation
Les stratégies et politiques de journalisation peuvent être configurées à l'aide d'un fichier suivant Java.
syntax - Configuration de Java Logging.
Exemple
Copiez le contenu suivant de orientdb-server-log.properties fichier et placez-le dans le $ORIENTDB_HOME/config fichier.
# 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
Pour indiquer à la JVM où le fichier de propriétés est placé, vous devez définir le "java.util.logging.config.file"propriété système. Par exemple, utilisez la commande suivante -
$ java -Djava.util.logging.config.file=mylog.properties ...
Définir le niveau de journalisation
Pour changer le niveau de journalisation sans modifier la configuration de journalisation, définissez simplement le paramètre "log.console.level" et "log.file.level"variables système aux niveaux requis.
Journalisation au démarrage
Voici les procédures pour définir la journalisation au niveau de démarrage de différentes manières.
Dans la configuration du serveur
Ouvrez le fichier orientdb-server-config.xml et ajoutez ou mettez à jour ces lignes à la fin du fichier dans la section <properties> -
<entry value = "fine" name = "log.console.level" />
<entry value = "fine" name = "log.file.level" />
Dans le script Server.sh (ou .bat)
Définissez la propriété système "log.console.level" et "log.file.level"aux niveaux souhaités en utilisant le paramètre -D de java.
$ java -Dlog.console.level = FINE ...
Journalisation au moment de l'exécution
Voici les procédures pour définir la journalisation au niveau de démarrage de différentes manières.
En utilisant le code Java
La variable système peut être définie au démarrage à l'aide de l'API System.setProperty (). L'extrait de code suivant est la syntaxe permettant de définir le niveau de journalisation à l'aide du code Java.
public void main(String[] args){
System.setProperty("log.console.level", "FINE");
...
}
Sur un serveur distant
Exécutez un HTTP POST contre l'URL: /server/log.<type>/ <level>, où -
- <type> peut être "console" ou "fichier"
- <level> est l'un des niveaux pris en charge
Exemple
L'exemple suivant utilise cURLpour exécuter une commande HTTP POST sur le serveur OrientDB. L'utilisateur et le mot de passe "root" du serveur ont été utilisés, remplacez-les par votre propre mot de passe.
Activez le niveau de traçage le plus fin pour la console -
curl -u root:root -X POST http://localhost:2480/server/log.console/FINEST
Activer le niveau de traçage le plus fin pour le fichier -
curl -u root:root -X POST http://localhost:2480/server/log.file/FINEST
Dans ce chapitre, vous pouvez obtenir des conseils généraux sur la façon d'optimiser votre application qui utilise OrientDB. Il existe trois façons d'augmenter les performances pour différents types de base de données.
Document Database Performance Tuning - Il utilise une technique qui permet d'éviter la création de documents pour chaque nouveau document.
Object Database Performance Tuning - Il utilise les techniques génériques pour améliorer les performances.
Distributed Configuration Tuning - Il utilise différentes méthodologies pour améliorer les performances en configuration distribuée.
Vous pouvez obtenir un réglage générique des performances en modifiant les paramètres de connexion Mémoire, JVM et à distance.
Paramètres de mémoire
Il existe différentes stratégies de réglage de la mémoire pour améliorer les performances.
Serveur et paramètres intégrés
Ces paramètres sont valides pour le composant Serveur et la JVM où l'application Java est exécutée à l'aide d'OrientDB en mode Embedded, en utilisant plocal.
La chose la plus importante lors du réglage est de s'assurer que les paramètres de la mémoire sont corrects. Ce qui peut faire une réelle différence, c'est le bon équilibre entre le tas et la mémoire virtuelle utilisée par Memory Mapping, en particulier sur les grands ensembles de données (Go, To et plus) où les structures de cache en mémoire comptent moins que les E / S brutes.
Par exemple, si vous pouvez attribuer un maximum de 8 Go au processus Java, il est généralement préférable d'attribuer un petit tas et un grand tampon de cache disque (mémoire hors tas).
Essayez la commande suivante pour augmenter la mémoire du tas.
java -Xmx800m -Dstorage.diskCache.bufferSize=7200 ...
le storage.diskCache.bufferSize paramètre (avec l'ancien stockage "local", c'était file.mmap.maxMemory) est en Mo et indique la quantité de mémoire à utiliser pour le composant Cache de disque. Par défaut, il est de 4 Go.
NOTE - Si la somme du tas maximal et du tampon de cache disque est trop élevée, cela pourrait entraîner un échange du système d'exploitation avec un ralentissement énorme.
Paramètres JVM
Les paramètres JVM sont codés dans les fichiers de commandes server.sh (et server.bat). Vous pouvez les modifier pour régler la JVM en fonction de votre utilisation et des paramètres hw / sw. Ajoutez la ligne suivante dans le fichier server.bat.
-server -XX:+PerfDisableSharedMem
Ce paramètre désactivera l'écriture des informations de débogage sur la JVM. Au cas où vous auriez besoin de profiler la JVM, supprimez simplement ce paramètre.
Connexions à distance
Il existe de nombreuses façons d'améliorer les performances lorsque vous accédez à la base de données à l'aide d'une connexion à distance.
Stratégie de récupération
Lorsque vous travaillez avec une base de données distante, vous devez faire attention à la stratégie de récupération utilisée. Par défaut, le client OrientDB charge uniquement l'enregistrement contenu dans le jeu de résultats. Par exemple, si une requête renvoie 100 éléments, mais si vous croisez ces éléments à partir du client, le client OrientDB charge paresseusement les éléments avec un autre appel réseau au serveur pour chaque enregistrement manqué.
Pool de connexions réseau
Chaque client, par défaut, utilise une seule connexion réseau pour parler avec le serveur. Plusieurs threads sur le même client partagent le même pool de connexions réseau.
Lorsque vous avez plusieurs threads, il peut y avoir un goulot d'étranglement car beaucoup de temps est passé à attendre une connexion réseau gratuite. C'est la raison pour laquelle il est important de configurer le pool de connexions réseau.
La configuration est très simple, juste 2 paramètres -
minPool- Il s'agit de la taille initiale du pool de connexions. La valeur par défaut est configurée en tant que paramètres globaux "client.channel.minPool".
maxPool- Il s'agit de la taille maximale que le pool de connexions peut atteindre. La valeur par défaut est configurée en tant que paramètres globaux "client.channel.maxPool".
Si toutes les connexions du pool sont occupées, le thread client attendra la première connexion libre.
Exemple de commande de configuration à l'aide des propriétés de la base de données.
database = new ODatabaseDocumentTx("remote:localhost/demo");
database.setProperty("minPool", 2);
database.setProperty("maxPool", 5);
database.open("admin", "admin");
Réglage de la configuration distribuée
Il existe de nombreuses façons d'améliorer les performances de la configuration distribuée.
Utiliser les transactions
Même lorsque vous mettez à jour des graphiques, vous devez toujours travailler dans les transactions. OrientDB vous permet de travailler en dehors d'eux. Les cas courants sont les requêtes en lecture seule ou les opérations massives et non simultanées peuvent être restaurées en cas d'échec. Lorsque vous exécutez sur une configuration distribuée, l'utilisation de transactions permet de réduire la latence. En effet, l'opération distribuée se produit uniquement au moment de la validation. La distribution d'une seule grande opération est beaucoup plus efficace que le transfert de petites opérations multiples, en raison de la latence.
Réplication vs sharding
La configuration distribuée OrientDB est définie sur la réplication complète. Il est important d'avoir plusieurs nœuds avec la même copie de la base de données pour les lectures à l'échelle. En fait, chaque serveur est indépendant de l'exécution des lectures et des requêtes. Si vous avez 10 nœuds de serveur, le débit de lecture est de 10x.
Avec les écritures, c'est le contraire: avoir plusieurs nœuds avec une réplication complète ralentit les opérations, si la réplication est synchrone. Dans ce cas, le partage de la base de données sur plusieurs nœuds vous permet d'augmenter les écritures, car seul un sous-ensemble de nœuds est impliqué lors de l'écriture. De plus, vous pourriez avoir une base de données plus grande qu'un nœud de serveur HD.
Augmentez vos écritures
Si vous avez un réseau lent et que vous avez une réplication synchrone (par défaut), vous pourriez payer le coût de la latence. En fait, lorsque OrientDB s'exécute de manière synchrone, il attend au moins lewriteQuorum. Cela signifie que si le writeQuorum est 3 et que vous avez 5 nœuds, le nœud du serveur coordinateur (où l'opération distribuée est lancée) doit attendre la réponse d'au moins 3 nœuds pour fournir la réponse au client.
Afin de maintenir la cohérence, writeQuorum doit être défini sur la majorité. Si vous avez 5 nœuds, la majorité est de 3. Avec 4 nœuds, c'est toujours 3. Mettre le writeQuorum à 3 au lieu de 4 ou 5 permet de réduire le coût de latence tout en maintenant la cohérence.
Réplication asynchrone
Pour accélérer les choses, vous pouvez configurer la réplication asynchrone pour supprimer le goulot d'étranglement de latence. Dans ce cas, le nœud serveur coordinateur exécute l'opération localement et donne la réponse au client. La réplication entière sera en arrière-plan. Si le quorum n'est pas atteint, les modifications seront annulées de manière transparente.
Augmentez vos lectures
Si vous définissez déjà writeQuorum sur la majorité des nœuds, vous pouvez laisser le readQuorumà 1 (valeur par défaut). Cela accélère toutes les lectures.
Lors de la mise à niveau, vous devez tenir compte du numéro de version et du format. Il existe trois types de formats: MAJOR, MINOR, PATCH.
MAJOR la version entraîne des modifications d'API incompatibles.
MINOR version implique des fonctionnalités de manière rétrocompatible.
PTCH version implique des corrections de bogues rétrocompatibles.
Pour synchroniser entre les versions mineure et majeure, vous devrez peut-être exporter et importer les bases de données. Parfois, vous devez souvent migrer la base de données de LOCAL vers PLOCAL et migrer le graphique vers RidBag.
Migrer de LOCAL Storage Engine vers PLOCAL
À partir de la version 1.5.x OrientDB est livré avec un tout nouveau moteur de stockage: PLOCAL (Paginé LOCAL). Il est persistant comme le LOCAL, mais stocke les informations d'une manière différente. Les points suivants montrent la comparaison entre PLOCAL et LOCAL -
Dans PLOCAL, les enregistrements sont stockés dans des fichiers de cluster, tandis que LOCAL était divisé entre le cluster et les segments de données.
PLOCAL est plus durable que LOCAL en raison du mode d'ajout en écriture.
PLOCAL a des verrous de contention mineurs sur les écritures, ce qui signifie plus de concurrence.
PLOCAL n'utilise pas les techniques de mappage de mémoire (MMap) donc le comportement est plus «prévisible».
Pour migrer votre stockage LOCAL vers le nouveau PLOCAL, vous devez exporter et réimporter la base de données en utilisant PLOCAL comme moteur de stockage. Voici la procédure.
Step 1 - Ouvrez un nouveau shell (Linux / Mac) ou une invite de commande (Windows).
Step 2- Exportez la base de données à l'aide de la console. Suivez la commande donnée pour exporter la démo de la base de données dansdemo.json.gzip fichier.
$ 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 - Sur un système de fichiers local, créez une nouvelle base de données à l'aide du moteur "plocal" -
orientdb> CREATE DATABASE plocal:/temp/newdb admin admin plocal graph
Step 4 - Importez l'ancienne base de données dans la nouvelle.
orientdb> IMPORT DATABASE /temp/demo.json.gzip -preserveClusterIDs=true
orientdb> QUIT
Si vous accédez à la base de données dans la même JVM, n'oubliez pas de changer l'URL de "local:" à "plocal:"
Migrer le graphique vers RidBag
Depuis OrientDB 1.7, le RidBag est une collection par défaut qui gère les relations de contiguïté dans les graphes. Alors que l'ancienne base de données gérée par un MVRB-Tree est entièrement compatible, vous pouvez mettre à jour votre base de données au format le plus récent.
Vous pouvez mettre à jour votre graphique via la console ou en utilisant le ORidBagMigration classe.
Se connecter à la base de données CONNECT plocal:databases/<graphdb-name>
Exécuter la commande de graphe de mise à niveau
Comme le SGBDR, OrientDB fournit également une sécurité basée sur des concepts, des utilisateurs et des rôles bien connus. Chaque base de données a ses propres utilisateurs et chaque utilisateur a un ou plusieurs rôles. Les rôles sont la combinaison de modes de travail et d'un ensemble d'autorisations.
Utilisateurs
Par défaut, OrientDB gère trois utilisateurs différents pour toutes les bases de données du serveur -
Admin - Cet utilisateur a accès à toutes les fonctions de la base de données sans limitation.
Reader- Cet utilisateur est un utilisateur en lecture seule. Le lecteur peut interroger tous les enregistrements de la base de données, mais ne peut ni les modifier ni les supprimer. Il n'a pas accès aux informations internes, telles que les utilisateurs et les rôles eux-mêmes.
Writer - Cet utilisateur est le même que le lecteur utilisateur, mais il peut également créer, mettre à jour et supprimer des enregistrements.
Travailler avec les utilisateurs
Lorsque vous êtes connecté à une base de données, vous pouvez interroger les utilisateurs actuels sur la base de données en utilisant SELECT requêtes sur OUser classe.
orientdb> SELECT RID, name, status FROM OUser
Si la requête ci-dessus est exécutée avec succès, vous obtiendrez la sortie suivante.
---+--------+--------+--------
# | @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).
Créer un nouvel utilisateur
Pour créer un nouvel utilisateur, utilisez la commande INSERT. N'oubliez pas, ce faisant, vous devez définir le statut sur ACTIVE et lui attribuer un rôle valide.
orientdb> INSERT INTO OUser SET
name = 'jay',
password = 'JaY',
status = 'ACTIVE',
roles = (SELECT FROM ORole WHERE name = 'reader')
Mettre à jour les utilisateurs
Vous pouvez modifier le nom de l'utilisateur avec l'instruction UPDATE.
orientdb> UPDATE OUser SET name = 'jay' WHERE name = 'reader'
De la même manière, vous pouvez également modifier le mot de passe de l'utilisateur.
orientdb> UPDATE OUser SET password = 'hello' WHERE name = 'reader'
OrientDB enregistre le mot de passe dans un format de hachage. Le déclencheurOUserTrigger crypte le mot de passe de manière transparente avant d'enregistrer l'enregistrement.
Désactiver les utilisateurs
Pour désactiver un utilisateur, utilisez UPDATE pour changer son état de ACTIVE à SUSPENDED. Par exemple, si vous souhaitez désactiver tous les utilisateurs à l'exception de l'administrateur, utilisez la commande suivante -
orientdb> UPDATE OUser SET status = 'SUSPENDED' WHERE name <> 'admin'
Les rôles
Un rôle détermine les opérations qu'un utilisateur peut effectuer sur une ressource. Cette décision dépend principalement du mode de fonctionnement et des règles. Les règles elles-mêmes fonctionnent différemment, selon le mode de fonctionnement.
Travailler avec des rôles
Lorsque vous êtes connecté à une base de données, vous pouvez interroger les rôles actuels sur la base de données en utilisant SELECT requêtes sur ORole classe.
orientdb> SELECT RID, mode, name, rules FROM ORole
Si la requête ci-dessus est exécutée avec succès, vous obtiendrez la sortie suivante.
--+------+----+--------+-------------------------------------------------------
# |@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).
Créer de nouveaux rôles
Pour créer un nouveau rôle, utilisez l'instruction INSERT.
orientdb> INSERT INTO ORole SET name = 'developer', mode = 0
Travailler avec les modes
Lorsque les règles déterminent ce que les utilisateurs appartenant à certains rôles peuvent faire sur les bases de données, les modes de travail déterminent comment OrientDB interprète ces règles. Il existe deux types de modes de fonctionnement, désignés par 1 et 0.
Allow All But (Rules)- Par défaut, c'est le mode super utilisateur. Spécifiez des exceptions à cela à l'aide des règles. Si OrientDB ne trouve aucune règle pour une ressource demandée, alors il permet à l'utilisateur d'exécuter l'opération. Utilisez ce mode principalement pour les utilisateurs expérimentés et les administrateurs. L'administrateur de rôle par défaut utilise ce mode par défaut et n'a pas de règles d'exception. Il est écrit comme 1 dans la base de données.
Deny All But (Rules)- Par défaut, ce mode n'autorise rien. Spécifiez des exceptions à cela à l'aide des règles. Si OrientDB trouve des règles pour une ressource demandée, alors il permet à l'utilisateur d'exécuter l'opération. Utilisez ce mode par défaut pour tous les utilisateurs classiques. Les rôles par défaut, lecteur et rédacteur, utilisent ce mode. Il est écrit 0 dans la base de données.
OrientDB fournit une interface utilisateur Web pour effectuer des opérations de base de données via l'interface graphique. Ce chapitre explique les différentes options disponibles dans OrientDB.
Page d'accueil du studio
Studio est une interface Web pour l'administration d'OrientDB fournie avec la distribution OrientDB.
Tout d'abord, vous devez démarrer le serveur OrientDB à l'aide de la commande suivante.
$ server.sh
Si vous exécutez OrientDB sur votre machine, l'interface Web est accessible via l'URL -
http://localhost:2480
Si la commande est exécutée avec succès, ce qui suit sera la sortie à l'écran.
Se connecter à une base de données existante
Pour vous connecter, sélectionnez une base de données dans la liste des bases de données et utilisez n'importe quel utilisateur de base de données. Par défaut (nom d'utilisateur / mot de passe)reader/reader peut lire les enregistrements de la base de données, writer/writer peut lire, créer, mettre à jour et supprimer des enregistrements, tandis que admin/admin a tous les droits.
Supprimer une base de données existante
Sélectionnez une base de données dans la liste des bases de données et cliquez sur l'icône de la corbeille. Studio ouvrira une fenêtre contextuelle de confirmation dans laquelle vous devrez insérer l'utilisateur du serveur et le mot de passe du serveur.
Cliquez ensuite sur le bouton "Supprimer la base de données". Vous pouvez trouver les informations d'identification du serveur dans le$ORIENTDB_HOME/config/orientdb-server-config.xml fichier.
<users>
<user name = "root" password = "pwd" resources = "*" />
</users>
Créer une nouvelle base de données
Pour créer une nouvelle base de données, cliquez sur le bouton "Nouveau DB" de la page d'accueil.
Les informations suivantes sont nécessaires pour créer une nouvelle base de données -
- Nom de la base de données
- Type de base de données (Document / Graphique)
- Type de stockage (plocal / mémoire)
- Utilisateur du serveur
- Mot de passe du serveur
Vous pouvez trouver les informations d'identification du serveur dans le $ORIENTDB_HOME/config/orientdbserver-config.xml fichier.
<users>
<user name = "root" password = "pwd" resources = "*" />
</users>
Une fois créé, Studio se connectera automatiquement à la nouvelle base de données.
Exécuter une requête
Studio prend en charge la reconnaissance automatique du langage que vous utilisez entre ceux pris en charge: SQL et Gremlin. Pendant l'écriture, utilisez la fonction de saisie semi-automatique en appuyant surCtrl + Space.
Les raccourcis suivants sont disponibles dans l'éditeur de requêtes -
Ctrl + Return - Pour exécuter la requête ou cliquez simplement sur le Run bouton.
Ctrl/Cmd + Z - Pour annuler les modifications.
Ctrl/Cmd + Shift + Z - Refaire les changements.
Ctrl/Cmd + F - Pour rechercher dans l'éditeur.
Ctrl/Cmd + / - Pour basculer un commentaire.
La capture d'écran suivante montre comment exécuter une requête.
En cliquant sur n'importe quel @rid dans l'ensemble de résultats, vous passerez en mode d'édition de document si l'enregistrement est un document, sinon vous passerez en édition de sommet.
Vous pouvez marquer vos requêtes en cliquant sur l'icône étoile dans l'ensemble de résultats ou dans l'éditeur. Pour parcourir les requêtes ajoutées aux favoris, cliquez sur l'icôneBookmarksbouton. Studio ouvrira la liste des signets sur la gauche, dans laquelle vous pourrez modifier / supprimer ou réexécuter des requêtes.
Studio enregistre les requêtes exécutées dans le stockage local du navigateur. Dans les paramètres de requête, vous pouvez configurer le nombre de requêtes que Studio conservera dans l'historique. Vous pouvez également rechercher une requête précédemment exécutée, supprimer toutes les requêtes de l'historique ou supprimer une seule requête.
Modifier le sommet
Pour modifier le sommet du graphique, accédez à la section Graphique. Exécutez ensuite la requête suivante.
Select From Customer
Lors de l'exécution réussie de la requête, voici la capture d'écran de sortie. Sélectionnez le sommet particulier dans le canevas du graphique à modifier.
Sélectionnez le symbole d'édition sur le sommet particulier. Vous obtiendrez l'écran suivant qui contient les options pour éditer le sommet.
Gestionnaire de schémas
OrientDB peut fonctionner en mode sans schéma, en mode schéma ou un mélange des deux. Ici, nous allons discuter du mode schéma. Cliquez sur la section Schéma en haut de l'interface utilisateur Web. Vous obtiendrez la capture d'écran suivante.
Créer une nouvelle classe
Pour créer une nouvelle classe, cliquez simplement sur le New Classbouton. La capture d'écran suivante apparaîtra. Vous devrez fournir les informations suivantes comme indiqué dans la capture d'écran pour créer la nouvelle classe.
Afficher tous les index
Lorsque vous souhaitez avoir une vue d'ensemble de tous les index créés dans votre base de données, cliquez simplement sur le bouton Tous les index dans l'interface utilisateur du schéma. Cela fournira un accès rapide à certaines informations sur les index (nom, type, propriétés, etc.) et vous pourrez les supprimer ou les reconstruire à partir d'ici.
Modifier la classe
Cliquez sur n'importe quelle classe dans la section schéma, vous obtiendrez la capture d'écran suivante.
Lors de la modification d'une classe, vous pouvez ajouter une propriété ou ajouter un nouvel index.
Ajouter une propriété
Cliquez sur le bouton Nouvelle propriété pour ajouter une propriété. Vous obtiendrez la capture d'écran suivante.
Vous devez fournir les détails suivants comme indiqué dans la capture d'écran pour ajouter une propriété.
Ajouter un index
Cliquez sur le bouton Nouvel index. Vous obtiendrez la capture d'écran suivante. Vous devez fournir les détails suivants comme indiqué dans la capture d'écran pour ajouter un index.
Éditeur de graphes
Cliquez sur la section graphique. Non seulement vous pouvez visualiser vos données dans un style graphique, mais vous pouvez également interagir avec le graphique et le modifier.
Pour remplir la zone graphique, saisissez une requête dans l'éditeur de requêtes ou utilisez la fonctionnalité Envoyer vers le graphique de l'interface utilisateur de navigation.
Ajouter des sommets
Pour ajouter un nouveau sommet dans votre base de données de graphes et dans la zone de canevas de graphe, vous devez appuyer sur le bouton Add Vertex. Cette opération se fait en deux étapes.
Dans la première étape, vous devez choisir la classe pour le nouveau Vertex, puis cliquer sur Suivant.
Dans la deuxième étape, vous devez insérer les valeurs de champ du nouveau sommet. Vous pouvez également ajouter des champs personnalisés car OrientDB prend en charge le mode sans schéma. Pour rendre le nouveau sommet persistant, cliquez sur «Enregistrer les modifications» et le sommet sera enregistré dans la base de données et ajouté à la zone de dessin.
Supprimer les sommets
Ouvrez le menu circulaire en cliquant sur le sommet que vous souhaitez supprimer. Ouvrez le sous-menu en passant la souris sur l'entrée de menu plus (...) puis cliquez sur l'icône de la corbeille.
Supprimer les sommets du canevas
Ouvrez le menu circulaire, ouvrez le sous-menu en passant la souris sur l'entrée de menu plus (...) puis cliquez sur l'icône de la gomme.
Inspecter les sommets
Si vous souhaitez jeter un œil à la propriété Vertex, cliquez sur l'icône en forme d'œil.
Sécurité
Studio 2.0 inclut la nouvelle gestion de la sécurité, dans laquelle vous pouvez gérer les utilisateurs et les rôles de manière graphique.
Utilisateurs
Vous pouvez effectuer les actions suivantes pour gérer les utilisateurs de la base de données -
- Rechercher des utilisateurs
- Ajouter des utilisateurs
- Supprimer des utilisateurs
- Modifier l'utilisateur: les rôles peuvent être modifiés en ligne, pour le nom, l'état et le mot de passe, cliquez sur le Edit bouton
Ajouter des utilisateurs
Pour ajouter un nouvel utilisateur, cliquez sur le Add User , renseignez les informations du nouvel utilisateur (nom, mot de passe, statut, rôles) puis enregistrez pour ajouter le nouvel utilisateur à la base de données.
Les rôles
Vous pouvez effectuer les actions suivantes pour gérer les rôles de base de données -
- Rôle de recherche
- Ajouter un rôle
- Supprimer le rôle
- Modifier le rôle
Ajouter un rôle
Pour ajouter un nouvel utilisateur, cliquez sur le Add Role , complétez les informations du nouveau rôle (nom, rôle parent, mode) puis enregistrez pour ajouter le nouveau rôle à la base de données.
Ajouter une règle à un rôle
Pour ajouter une nouvelle règle de sécurité pour le rôle sélectionné, cliquez sur l'icône Add Rulebouton. Cela vous demandera la chaîne de la ressource que vous souhaitez sécuriser. Ensuite, vous pouvez configurer les autorisations CRUD sur la ressource nouvellement créée.
Semblable au SGBDR, OrientDB prend en charge JDBC. Pour cela, nous devons d'abord configurer l'environnement pour la programmation JDBC. Voici la procédure pour créer une connexion entre votre application et votre base de données.
Tout d'abord, nous devons télécharger le pilote JDBC. Visitez le lien suivanthttps://code.google.com/archive/p/orient/downloads pour télécharger OrientDB-JDBC.
Voici les cinq étapes de base pour atteindre la connectivité OrientDB-jdbc.
- Charger le pilote JDBC
- Créer une connexion
- Créer une déclaration
- Exécuter l'instruction
- Fermer la connexion
Exemple
Essayez l'exemple suivant pour comprendre la connectivité OrientDB-JDBC. Considérons que nous avons une table des employés qui contient les champs suivants et leurs types.
Sr.No. | Nom de domaine | Type |
---|---|---|
1 | Id | Entier |
2 | Nom | Chaîne |
3 | Un salaire | Entier |
4 | Date d'inscription | Date |
Vous pouvez créer un schéma (table) en exécutant les commandes suivantes.
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
Après avoir exécuté toutes les commandes, vous obtiendrez la table Employé avec les champs suivants, le nom de l'employé avec les champs id, age et join_date.
Enregistrez le code suivant dans OrientJdbcDemo.java fichier.
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();
}
}
La commande suivante est utilisée pour compiler le programme ci-dessus.
$ javac –classpath:.:orientdb-jdbc-1.0-SNAPSHOT.jar OrientJdbcDemo.java $ java –classpath:.:orientdb-jdbc-1.0-SNAPSHOT.jar OrientJdbcDemo
Si la commande ci-dessus est exécutée avec succès, vous obtiendrez la sortie suivante.
Records Successfully Inserted
Le pilote OrientDB pour Python utilise le protocole binaire. PyOrient est le nom du projet git hub qui permet de connecter OrientDB avec Python. Il fonctionne avec OrientDB version 1.7 et ultérieure.
La commande suivante est utilisée pour installer PyOrient.
pip install pyorient
Vous pouvez utiliser le fichier de script nommé demo.py pour effectuer les tâches suivantes -
Créer une instance client signifie créer une connexion.
Créer une base de données nommée DB_Demo.
Ouvrez la base de données nommée DB_Demo.
Créez la classe ma_classe.
Créez l'identifiant et le nom des propriétés.
Insérez l'enregistrement dans ma 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')")
Exécutez le script ci-dessus à l'aide de la commande suivante.
$ python demo.py