Base de données H2 - Guide rapide
H2 est une base de données Java légère et open source. Il peut être intégré dans des applications Java ou s'exécuter en mode client-serveur. Principalement, la base de données H2 peut être configurée pour s'exécuter en tant que base de données en mémoire, ce qui signifie que les données ne persisteront pas sur le disque. En raison de la base de données intégrée, elle n'est pas utilisée pour le développement de la production, mais principalement pour le développement et les tests.
Cette base de données peut être utilisée en mode embarqué ou en mode serveur. Voici les principales caractéristiques de la base de données H2 -
- API JDBC extrêmement rapide et open source
- Disponible en modes embarqué et serveur; bases de données en mémoire
- Application console basée sur un navigateur
- Faible encombrement - Taille de fichier jar d'environ 1,5 Mo
Caractéristiques de la base de données H2
Les principales caractéristiques de la base de données H2 sont les suivantes -
C'est un moteur de base de données extrêmement rapide.
H2 est open source et écrit en Java.
Il prend en charge les API SQL et JDBC standard. Il peut également utiliser le pilote ODBC PostgreSQL.
Il a intégré et mode serveur.
H2 soutient clustering et multi-version concurrency.
Il a de fortes fonctionnalités de sécurité.
Caractéristiques supplémentaires
Voici quelques fonctionnalités supplémentaires de H2 Database -
H2 est une base de données et des tables sur disque ou en mémoire, support de base de données en lecture seule, tables temporaires.
H2 fournit une prise en charge des transactions (lecture validée), des connexions multiples à validation en 2 phases, un verrouillage au niveau de la table.
H2 est un optimiseur basé sur les coûts, utilisant un algorithme génétique pour les requêtes complexes, zeroadministration.
H2 contient un support de jeu de résultats défilable et modifiable, un grand jeu de résultats, un tri des résultats externe, les fonctions peuvent renvoyer un jeu de résultats.
H2 prend en charge la base de données cryptée (AES), le cryptage de mot de passe SHA-256, les fonctions de cryptage et SSL.
Composants dans la base de données H2
Pour utiliser la base de données H2, vous devez disposer des composants suivants -
- Un navigateur Web
- Un serveur de console H2
Il s'agit d'une application client / serveur, donc le serveur et le client (un navigateur) sont nécessaires pour l'exécuter.
H2 est une base de données écrite en Java. Nous pouvons facilement intégrer cette base de données à notre application en utilisant JDBC. Nous pouvons l'exécuter sur de nombreuses plates-formes différentes ou sur n'importe quelle version de Java Runtime Environment. Cependant, avant d'installer la base de données, Java doit être installé sur le système.
Vérifier l'installation de Java
Si JDK est installé sur le système, essayez la commande suivante pour vérifier la version Java.
java –version
Si JDk est correctement installé dans le système, nous obtiendrons la sortie suivante.
java version "1.8.0_91"
Java(TM) SE Runtime Environment (build 1.8.0_91-b14)
Java HotSpot(TM) 64-Bit Server VM (build 25.91-b14, mixed mode)
Si JDK n'est pas installé dans le système, visitez le lien suivant pour installer JDK .
Installer la base de données H2
Nous pouvons exécuter cette base de données sur de nombreuses plates-formes différentes. Dans ce chapitre, nous allons découvrir l'installation de la base de données H2 sous Windows.
Voici les étapes pour installer la base de données H2 sur le système d'exploitation Windows.
Étape 1: Téléchargez le fichier d'installation H2
Téléchargez la dernière version de la base de données H2 à partir du lien indiqué. Dans ce lien, vous obtiendrez la dernière version de la base de données H2 en deux types. L'un est de type Windows Installer (c'est-à-dire un fichier .exe) et le second est un fichier zip indépendant de la plate-forme pour les autres systèmes d'exploitation.
Cliquez sur le programme d'installation Windows pour télécharger la base de données H2 compatible avec Windows après avoir téléchargé le fichier .exe. Dans ce cas, nous utilisons H2 Database avec la version 1.4.192.
Étape 2: Installez la base de données H2
Après le téléchargement, nous obtenons le fichier d'installation de H2 Windows (c.-à-d. H2-setup-aaaa-mm-jj.exe) dans le répertoire Téléchargements. Pour démarrer le processus d'installation de H2 Database, double-cliquez sur le fichier d'installation.
L'écran suivant est la première étape du processus d'installation. Fournissez un chemin où nous voulons installer le serveur de base de données H2 comme indiqué dans la capture d'écran suivante.
Comme le montre la capture d'écran ci-dessus, par défaut, cela prendra C:\ProgramFiles (x86)\H2comme dossier de destination. Cliquez sur suivant pour passer à l'étape suivante. L'écran suivant apparaît.
Dans la capture d'écran ci-dessus, cliquez sur le bouton Installer pour démarrer le processus d'installation. Après l'installation, nous obtenons la capture d'écran suivante.
Cliquez sur Terminer pour terminer le processus d'installation.
Étape 3: Vérifiez l'installation de la base de données H2
Après l'installation, vérifions l'installation de la base de données dans le système. Cliquez sur Windows → tapez H2 Console → Cliquez sur l'icône de la console H2. Connectez-vous à l'URLhttp://localhost:8082. Au moment de la connexion, la base de données H2 demandera l'enregistrement de la base de données comme indiqué dans la capture d'écran suivante.
Remplissez tous les détails dans la boîte de dialogue ci-dessus, tels que les paramètres enregistrés, le nom des paramètres, la classe de pilote, l'URL JDBC, le nom d'utilisateur et le mot de passe. Dans l'URL JDBC, indiquez que la base de données est localisée et le nom de la base de données. Le nom d'utilisateur et le mot de passe sont les champs du nom d'utilisateur et du mot de passe de la base de données. Cliquez sur Connecter.
La page d'accueil de la base de données apparaît comme indiqué dans la capture d'écran suivante.
La commande Select est utilisée pour récupérer les données d'enregistrement d'une table ou de plusieurs tables. Si nous concevons une requête de sélection, elle renvoie les données sous la forme d'une table de résultats appeléeresult sets.
Syntaxe
La syntaxe de base de l'instruction SELECT est la suivante -
SELECT [ TOP term ] [ DISTINCT | ALL ] selectExpression [,...]
FROM tableExpression [,...] [ WHERE expression ]
[ GROUP BY expression [,...] ] [ HAVING expression ]
[ { UNION [ ALL ] | MINUS | EXCEPT | INTERSECT } select ] [ ORDER BY order [,...] ]
[ [ LIMIT expression ] [ OFFSET expression ] [ SAMPLE_SIZE rowCountInt ] ]
[ FOR UPDATE ]
Pour récupérer tous les champs disponibles, utilisez la syntaxe suivante.
SELECT * FROM table_name;
Exemple
Considérez la table CUSTOMER ayant les enregistrements suivants -
+----+----------+-----+-----------+----------+
| ID | NAME | AGE | ADDRESS | SALARY |
+----+----------+-----+-----------+----------+
| 1 | Ramesh | 32 | Ahmedabad | 2000.00 |
| 2 | Khilan | 25 | Delhi | 1500.00 |
| 3 | kaushik | 23 | Kota | 2000.00 |
| 4 | Chaitali | 25 | Mumbai | 6500.00 |
| 5 | Hardik | 27 | Bhopal | 8500.00 |
| 6 | Komal | 22 | MP | 4500.00 |
| 7 | Muffy | 24 | Indore | 10000.00 |
+----+----------+-----+-----------+----------+
Pour obtenir la table client avec les données données, exécutez les requêtes suivantes.
CREATE TABLE CUSTOMER (id number, name varchar(20), age number, address varchar(20),
salary number);
INSERT into CUSTOMER values (1, 'Ramesh', 32, 'Ahmedabad', 2000);
INSERT into CUSTOMER values (2, 'Khilan', 25, 'Delhi', 1500);
INSERT into CUSTOMER values (3, 'kaushik', 23, 'Kota', 2000);
INSERT into CUSTOMER values (4, 'Chaitali', 25, 'Mumbai', 6500);
INSERT into CUSTOMER values (5, 'Hardik', 27, 'Bhopal', 8500);
INSERT into CUSTOMER values (6, 'Komal', 22, 'MP', 4500);
INSERT into CUSTOMER values (7, 'Muffy', 24, 'Indore', 10000);
La commande suivante est un exemple, qui extrait les champs ID, Nom et Salaire des clients disponibles dans la table CUSTOMER.
SELECT ID, NAME, SALARY FROM CUSTOMERS;
La commande ci-dessus produit le résultat suivant.
+----+----------+----------+
| ID | NAME | SALARY |
+----+----------+----------+
| 1 | Ramesh | 2000.00 |
| 2 | Khilan | 1500.00 |
| 3 | kaushik | 2000.00 |
| 4 | Chaitali | 6500.00 |
| 5 | Hardik | 8500.00 |
| 6 | Komal | 4500.00 |
| 7 | Muffy | 10000.00 |
+----+----------+----------+
Utilisez la requête suivante pour récupérer tous les champs de la table CUSTOMERS.
SQL> SELECT * FROM CUSTOMERS;
La requête ci-dessus produit le résultat suivant -
+----+----------+-----+-----------+----------+
| ID | NAME | AGE | ADDRESS | SALARY |
+----+----------+-----+-----------+----------+
| 1 | Ramesh | 32 | Ahmedabad | 2000.00 |
| 2 | Khilan | 25 | Delhi | 1500.00 |
| 3 | kaushik | 23 | Kota | 2000.00 |
| 4 | Chaitali | 25 | Mumbai | 6500.00 |
| 5 | Hardik | 27 | Bhopal | 8500.00 |
| 6 | Komal | 22 | MP | 4500.00 |
| 7 | Muffy | 24 | Indore | 10000.00 |
+----+----------+-----+-----------+----------+
L'instruction SQL INSERT est utilisée pour ajouter de nouvelles lignes de données à une table de la base de données.
Syntaxe
Voici la syntaxe de base de l'instruction INSERT INTO.
INSERT INTO tableName
{ [ ( columnName [,...] ) ]
{ VALUES
{ ( { DEFAULT | expression } [,...] ) } [,...] | [ DIRECT ] [ SORTED ] select } } |
{ SET { columnName = { DEFAULT | expression } } [,...] }
En utilisant cette instruction INSERT, nous pouvons insérer un nouvel enregistrement ou de nouvelles lignes dans une table. Lors de l'utilisation de la clause DIRECT, les résultats sont directement affectés à la table cible sans aucune étape intermédiaire. Cependant, lors de l'ajout de valeurs pour toutes les colonnes de la table, assurez-vous que l'ordre des valeurs est dans le même ordre que les colonnes de la table.
Exemple
Prenons un exemple et essayons d'insérer les enregistrements donnés suivants dans la table Customer.
ID | Nom | Âge | Adresse | Un salaire |
---|---|---|---|---|
1 | Ramesh | 32 | Ahmedabad | 2000 |
2 | Khilan | 25 | Delhi | 1500 |
3 | Kaushik | 23 | Kota | 2000 |
4 | Chaitail | 25 | Bombay | 6500 |
5 | Hardik | 27 | Bhopal | 8500 |
6 | Komal | 22 | MP | 4500 |
sept | Muffy | 24 | Indore | 10 000 |
Nous pouvons obtenir tous les enregistrements donnés dans la table client en exécutant les commandes suivantes.
INSERT INTO CUSTOMER VALUES (1, 'Ramesh', 32, 'Ahmedabad', 2000);
INSERT INTO CUSTOMER VALUES (2, 'Khilan', 25, 'Delhi', 1500);
INSERT INTO CUSTOMER VALUES (3, 'kaushik', 23, 'Kota', 2000);
INSERT INTO CUSTOMER VALUES (4, 'Chaitali', 25, 'Mumbai', 6500);
INSERT INTO CUSTOMER VALUES (5, 'Hardik', 27, 'Bhopal', 8500);
INSERT INTO CUSTOMER VALUES (6, 'Komal', 22, 'MP', 4500);
INSERT INTO CUSTOMER VALUES (7, 'Muffy', 24, 'Indore', 10000);
La requête UPDATE est utilisée pour mettre à jour ou modifier les enregistrements existants dans une table. Nous pouvons utiliser la clause WHERE avec la requête UPDATE pour mettre à jour les lignes sélectionnées, sinon toutes les lignes seraient affectées.
Syntaxe
Voici la syntaxe de base de la requête UPDATE.
UPDATE tableName [ [ AS ] newTableAlias ] SET
{ { columnName = { DEFAULT | expression } } [,...] } |
{ ( columnName [,...] ) = ( select ) }
[ WHERE expression ] [ ORDER BY order [,...] ] [ LIMIT expression ]
Dans cette syntaxe UPDATE, nous pouvons combiner plusieurs conditions en utilisant des clauses AND ou OR.
Exemple
Considérez la table CUSTOMER ayant les enregistrements suivants.
+----+----------+-----+-----------+----------+
| ID | NAME | AGE | ADDRESS | SALARY |
+----+----------+-----+-----------+----------+
| 1 | Ramesh | 32 | Ahmedabad | 2000.00 |
| 2 | Khilan | 25 | Delhi | 1500.00 |
| 3 | kaushik | 23 | Kota | 2000.00 |
| 4 | Chaitali | 25 | Mumbai | 6500.00 |
| 5 | Hardik | 27 | Bhopal | 8500.00 |
| 6 | Komal | 22 | MP | 4500.00 |
| 7 | Muffy | 24 | Indore | 10000.00 |
+----+----------+-----+-----------+----------+
Si vous souhaitez obtenir la table client avec les données fournies, exécutez les requêtes suivantes.
CREATE TABLE CUSTOMER (id number, name varchar(20), age number, address varchar(20),
salary number);
INSERT into CUSTOMER values (1, 'Ramesh', 32, 'Ahmedabad', 2000);
INSERT into CUSTOMER values (2, 'Khilan', 25, 'Delhi', 1500);
INSERT into CUSTOMER values (3, 'kaushik', 23, 'Kota', 2000);
INSERT into CUSTOMER values (4, 'Chaitali', 25, 'Mumbai', 6500);
INSERT into CUSTOMER values (5, 'Hardik', 27, 'Bhopal', 8500);
INSERT into CUSTOMER values (6, 'Komal', 22, 'MP', 4500);
INSERT into CUSTOMER values (7, 'Muffy', 24, 'Indore', 10000);
La commande suivante est un exemple, qui mettrait à jour ADDRESS pour un client dont l'ID est 6 -
UPDATE CUSTOMERS SET ADDRESS = 'Pune' WHERE ID = 6;
Désormais, la table CUSTOMERS contiendra les enregistrements suivants. Nous pouvons vérifier les enregistrements de la table client en exécutant la requête suivante.
SELECT * FROM CUSTOMERS;
La requête ci-dessus produit le résultat suivant.
+----+----------+-----+-----------+----------+
| ID | NAME | AGE | ADDRESS | SALARY |
+----+----------+-----+-----------+----------+
| 1 | Ramesh | 32 | Ahmedabad | 2000.00 |
| 2 | Khilan | 25 | Delhi | 1500.00 |
| 3 | kaushik | 23 | Kota | 2000.00 |
| 4 | Chaitali | 25 | Mumbai | 6500.00 |
| 5 | Hardik | 27 | Bhopal | 8500.00 |
| 6 | Komal | 22 | Pune | 4500.00 |
| 7 | Muffy | 24 | Indore | 10000.00 |
+----+----------+-----+-----------+----------+
Pour modifier toutes les valeurs des colonnes ADDRESS et SALARY dans la table CUSTOMERS, nous n'avons pas besoin d'utiliser la clause WHERE. La requête UPDATE serait la suivante -
UPDATE CUSTOMERS SET ADDRESS = 'Pune', SALARY = 1000.00;
Désormais, la table CUSTOMERS contiendra les enregistrements suivants. Nous pouvons vérifier les enregistrements de la table client en exécutant la requête suivante.
SELECT * FROM CUSTOMERS;
La requête ci-dessus produit le résultat suivant -
+----+----------+-----+---------+---------+
| ID | NAME | AGE | ADDRESS | SALARY |
+----+----------+-----+---------+---------+
| 1 | Ramesh | 32 | Pune | 1000.00 |
| 2 | Khilan | 25 | Pune | 1000.00 |
| 3 | kaushik | 23 | Pune | 1000.00 |
| 4 | Chaitali | 25 | Pune | 1000.00 |
| 5 | Hardik | 27 | Pune | 1000.00 |
| 6 | Komal | 22 | Pune | 1000.00 |
| 7 | Muffy | 24 | Pune | 1000.00 |
+----+----------+-----+---------+---------+
La requête SQL DELETE est utilisée pour supprimer les enregistrements existants d'une table. Nous pouvons utiliser la clause WHERE avec la requête DELETE pour supprimer les enregistrements sélectionnés, sinon tous les enregistrements seront supprimés.
Syntaxe
Voici la syntaxe de requête générique de la commande de suppression.
DELETE [ TOP term ] FROM tableName [ WHERE expression ] [ LIMIT term ]
La syntaxe ci-dessus supprime les lignes d'une table. Si TOP ou LIMIT est spécifié, au plus le nombre spécifié de lignes est supprimé (aucune limite si nul ou inférieur à zéro).
Exemple
Considérez la table CUSTOMER ayant les enregistrements suivants.
+----+----------+-----+-----------+----------+
| ID | NAME | AGE | ADDRESS | SALARY |
+----+----------+-----+-----------+----------+
| 1 | Ramesh | 32 | Ahmedabad | 2000.00 |
| 2 | Khilan | 25 | Delhi | 1500.00 |
| 3 | kaushik | 23 | Kota | 2000.00 |
| 4 | Chaitali | 25 | Mumbai | 6500.00 |
| 5 | Hardik | 27 | Bhopal | 8500.00 |
| 6 | Komal | 22 | MP | 4500.00 |
| 7 | Muffy | 24 | Indore | 10000.00 |
+----+----------+-----+-----------+----------+
La commande suivante supprimera les détails du client, dont l'ID est 6.
DELETE FROM CUSTOMERS WHERE ID = 6;
Après l'exécution de la commande ci-dessus, vérifiez la table Client en exécutant la commande suivante.
SELECT * FROM CUSTOMERS;
La commande ci-dessus produit la sortie suivante -
+----+----------+-----+-----------+----------+
| ID | NAME | AGE | ADDRESS | SALARY |
+----+----------+-----+-----------+----------+
| 1 | Ramesh | 32 | Ahmedabad | 2000.00 |
| 2 | Khilan | 25 | Delhi | 1500.00 |
| 3 | kaushik | 23 | Kota | 2000.00 |
| 4 | Chaitali | 25 | Mumbai | 6500.00 |
| 5 | Hardik | 27 | Bhopal | 8500.00 |
| 7 | Muffy | 24 | Indore | 10000.00 |
+----+----------+-----+-----------+----------+
Si nous voulons SUPPRIMER tous les enregistrements de la table CUSTOMERS, nous n'utilisons pas la clause WHERE. La requête DELETE serait la suivante.
DELETE FROM CUSTOMER;
Après avoir exécuté la commande ci-dessus, aucun enregistrement ne sera disponible dans la table Client.
BACKUP est la commande utilisée pour prendre la sauvegarde de la base de données dans un fichier .zip séparé. Les objets ne sont pas verrouillés et lors de la sauvegarde, le journal des transactions est également copié. Des droits d'administrateur sont requis pour exécuter cette commande.
Syntaxe
Voici la syntaxe générique de la commande de sauvegarde.
BACKUP TO fileNameString;
Exemple
Dans cet exemple, prenons une sauvegarde de la base de données actuelle dans backup.zipfichier. Utilisez la commande suivante pour la même chose.
BACKUP TO 'backup.zip';
Lors de l'exécution de la commande ci-dessus, vous obtiendrez le fichier backup.zip dans votre système de fichiers local.
CALL est une commande SQL qui appartient au serveur de base de données H2. Cette commande est utilisée pour calculer une expression simple. Il renvoie le résultat de l'expression donnée dans un champ de colonne unique. Lorsqu'il renvoie un tableau de résultats, chaque élément du tableau est affiché sous forme de valeur de colonne.
Syntaxe
Voici la syntaxe générique de la commande CALL.
CALL expression;
Nous pouvons utiliser l'expression arithmétique dans cette syntaxe.
Exemple
Prenons un exemple et exécutons une expression arithmétique (15 * 25) en utilisant la commande call.
CALL 15*25;
La commande ci-dessus produit la sortie suivante.
375 |
---|
375 |
La commande EXPLAIN affiche le plan d'exécution d'une instruction. Lorsque nous exécutons une instruction à l'aide de la commande EXPLAIN ANALYZE, le plan de requête inclura le nombre réel de balayages de lignes pour chaque table.
Syntaxe
Voici la syntaxe générique de la commande EXPLAIN.
EXPLAIN { [ PLAN FOR ] | ANALYZE } { select | insert | update | delete | merge}
Parallèlement à cette syntaxe, nous pouvons utiliser sélectionner, insérer, supprimer et fusionner.
Exemple
Cet exemple explique les détails du plan de requête du client avec l'ID 1.
EXPLAIN SELECT * FROM CUSTOMER WHERE ID = 1;
La commande ci-dessus produit la sortie suivante -
La commande MERGE est utilisée pour mettre à jour les lignes existantes et insérer de nouvelles lignes dans une table. La colonne de clé primaire joue un rôle important lors de l'utilisation de cette commande; il est utilisé pour trouver la ligne.
Syntaxe
Voici la syntaxe générique de la commande MERGE.
MERGE INTO tableName [ ( columnName [,...] ) ]
[ KEY ( columnName [,...] ) ]
{ VALUES { ( { DEFAULT | expression } [,...] ) } [,...] | select }
Dans la syntaxe ci-dessus, la clause KEY est utilisée pour spécifier le nom de la colonne de clé primaire. Avec la clause VALUES, nous pouvons utiliser des valeurs primitives pour insérer ou nous pouvons récupérer et stocker d'autres valeurs de table dans cette table à l'aide de la commande select.
Exemple
Dans cet exemple, essayons d'ajouter un nouvel enregistrement dans la table Clients. Voici les détails du nouvel enregistrement dans le tableau.
Nom de colonne | Valeur |
---|---|
ID | 8 |
NOM | Lokesh |
ÂGE | 32 |
ADRESSE | Hyderabad |
UN SALAIRE | 2500 |
En utilisant la requête suivante, insérons l'enregistrement donné dans la requête de base de données H2.
MERGE INTO CUSTOMER KEY (ID) VALUES (8, 'Lokesh', 32, 'Hyderabad', 2500);
La requête ci-dessus produit la sortie suivante.
Update count: 1
Vérifions les enregistrements de la table Customer en exécutant la requête suivante.
SELECT * FROM CUSTOMER;
La requête ci-dessus produit la sortie suivante.
ID | Nom | Âge | Adresse | Un salaire |
---|---|---|---|---|
1 | Ramesh | 32 | Ahmedabad | 2000 |
2 | Khilan | 25 | Delhi | 1500 |
3 | Kaushik | 23 | Kota | 2000 |
4 | Chaitali | 25 | Bombay | 6500 |
5 | Hardik | 27 | Bhopal | 8500 |
6 | Komal | 22 | MP | 4500 |
sept | Muffy | 24 | Indore | 10 000 |
8 | Lokesh | 32 | Hyderabad | 2500 |
Essayons maintenant de mettre à jour l'enregistrement en utilisant le Mergecommander. Voici les détails de l'enregistrement à mettre à jour.
Nom de colonne | Valeur |
---|---|
ID | 8 |
NOM | Loki |
ÂGE | 32 |
ADRESSE | Hyderabad |
UN SALAIRE | 3000 |
Utilisez la requête suivante pour insérer l'enregistrement donné dans la requête de base de données H2.
MERGE INTO CUSTOMER KEY (ID) VALUES (8, 'Loki', 32, 'Hyderabad', 3000);
La requête ci-dessus produit la sortie suivante.
Update count: 1
Vérifions les enregistrements de la table Customer en exécutant la requête suivante.
SELECT * FROM CUSTOMER;
La requête ci-dessus produit la sortie suivante -
ID | Nom | Âge | Adresse | Un salaire |
---|---|---|---|---|
1 | Ramesh | 32 | Ahmedabad | 2000 |
2 | Khilan | 25 | Delhi | 1500 |
3 | Kaushik | 23 | Kota | 2000 |
4 | Chaitali | 25 | Bombay | 6500 |
5 | Hardik | 27 | Bhopal | 8500 |
6 | Komal | 22 | MP | 4500 |
sept | Muffy | 24 | Indore | 10 000 |
8 | Loki | 32 | Hyderabad | 3000 |
SHOW est une commande utilisée pour afficher la liste des schémas, tables ou colonnes de la table.
Syntaxe
Voici la syntaxe générique de la commande SHOW.
SHOW { SCHEMAS | TABLES [ FROM schemaName ] |
COLUMNS FROM tableName [ FROM schemaName ] }
Exemple
La commande suivante peut être utilisée pour obtenir la liste des tables de la base de données actuelle.
SHOW TABLES;
La commande ci-dessus produit la sortie suivante.
NOM DE LA TABLE | TABLE_SCHEMA |
---|---|
CLIENT | PUBLIQUE |
EMP | PUBLIQUE |
CREATE est une commande SQL générique utilisée pour créer des tables, des schémas, des séquences, des vues et des utilisateurs dans le serveur de base de données H2.
Créer une table
Create Table est une commande utilisée pour créer une table définie par l'utilisateur dans la base de données actuelle.
Syntaxe
Voici la syntaxe générique de la commande Créer une table.
CREATE [ CACHED | MEMORY ] [ TEMP | [ GLOBAL | LOCAL ] TEMPORARY ]
TABLE [ IF NOT EXISTS ] name
[ ( { columnDefinition | constraint } [,...] ) ]
[ ENGINE tableEngineName [ WITH tableEngineParamName [,...] ] ]
[ NOT PERSISTENT ] [ TRANSACTIONAL ]
[ AS select ]
En utilisant la syntaxe générique de la commande Create Table, nous pouvons créer différents types de tables telles que des tables mises en cache, des tables mémoire et des tables temporaires. Voici la liste pour décrire les différentes clauses de la syntaxe donnée.
CACHED- Les tables mises en cache sont le type par défaut pour les tables régulières. Cela signifie que le nombre de lignes n'est pas limité par la mémoire principale.
MEMORY- Les tables mémoire sont le type par défaut pour les tables temporaires. Cela signifie que les tables de mémoire ne doivent pas devenir trop volumineuses et que les données d'index sont conservées dans la mémoire principale.
TEMPORARY- Les tables temporaires sont supprimées lors de la fermeture ou de l'ouverture d'une base de données. Fondamentalement, les tables temporaires sont de deux types -
Type GLOBAL - Accessible par toutes les connexions.
Type LOCAL - Accessible par la connexion actuelle.
Le type par défaut des tables temporaires est le type global. Les index des tables temporaires sont conservés dans la mémoire principale, sauf si la table temporaire est créée à l'aide de CREATE CACHED TABLE.
ENGINE - L'option ENGINE n'est requise que lorsque des implémentations de table personnalisées sont utilisées.
NOT PERSISTENT - C'est un modificateur pour garder les données de table complètes en mémoire et toutes les lignes sont perdues lorsque la base de données est fermée.
TRANSACTIONAL - C'est un mot-clé qui valide une transaction ouverte et cette commande ne prend en charge que les tables temporaires.
Exemple
Dans cet exemple, créons une table nommée tutorials_tbl en utilisant les données données suivantes.
Sr.Non | Nom de colonne | Type de données |
---|---|---|
1 | ID | Int |
2 | Titre | Varchar (50) |
3 | Auteur | Varchar (20) |
4 | Date de soumission | Date |
La requête suivante est utilisée pour créer une table tutorials_tbl avec les données de colonne données.
CREATE TABLE tutorials_tbl (
id INT NOT NULL,
title VARCHAR(50) NOT NULL,
author VARCHAR(20) NOT NULL,
submission_date DATE
);
La requête ci-dessus produit la sortie suivante.
(0) rows effected
Créer un schéma
Create Schema est une commande utilisée pour créer un schéma dépendant de l'utilisateur sous une autorisation particulière (sous l'utilisateur actuellement enregistré).
Syntaxe
Voici la syntaxe générique de la commande Créer un schéma.
CREATE SCHEMA [ IF NOT EXISTS ] name [ AUTHORIZATION ownerUserName ]
Dans la syntaxe générique ci-dessus, AUTHORIZATION est un mot clé utilisé pour fournir le nom d'utilisateur respectif. Cette commande est facultative, ce qui signifie que si nous ne fournissons pas le nom d'utilisateur, elle considérera l'utilisateur actuel. L'utilisateur qui exécute la commande doit avoir des droits d'administrateur, ainsi que le propriétaire.
Cette commande valide une transaction ouverte dans cette connexion.
Exemple
Dans cet exemple, créons un schéma nommé test_schema sous utilisateur SA, en utilisant la commande suivante.
CREATE SCHEMA test_schema AUTHORIZATION sa;
La commande ci-dessus produit la sortie suivante.
(0) rows effected
Créer une séquence
La séquence est un concept utilisé pour générer un nombre en suivant une séquence pour id ou toute valeur de colonne aléatoire.
Syntaxe
Voici la syntaxe générique de la commande create sequence.
CREATE SEQUENCE [ IF NOT EXISTS ] newSequenceName [ START WITH long ]
[ INCREMENT BY long ]
[ MINVALUE long | NOMINVALUE | NO MINVALUE ]
[ MAXVALUE long | NOMAXVALUE | NO MAXVALUE ]
[ CYCLE long | NOCYCLE | NO CYCLE ]
[ CACHE long | NOCACHE | NO CACHE ]
Cette syntaxe générique est utilisée pour créer une séquence. Le type de données d'une séquence estBIGINT. Dans cette séquence, les valeurs ne sont jamais réutilisées, même lorsque la transaction est annulée.
Exemple
Dans cet exemple, créons une séquence nommée SEQ_ID, en utilisant la requête suivante.
CREATE SEQUENCE SEQ_ID;
La requête ci-dessus produit la sortie suivante.
(0) rows effected
ALTER est une commande utilisée pour changer la structure de la table en ajoutant différentes clauses au altercommander. Sur la base du scénario, nous devons ajouter une clause respective à la commande alter. Dans ce chapitre, nous discuterons de divers scénarios de commande alter.
Modifier la table Ajouter
Alter Table Add est une commande utilisée pour ajouter une nouvelle colonne à une table avec le type de données respectif. Cette commande valide la transaction dans cette connexion.
Syntaxe
Voici la syntaxe générique de la commande Alter Table Add.
ALTER TABLE [ IF EXISTS ] tableName ADD [ COLUMN ]
{ [ IF NOT EXISTS ] columnDefinition [ { BEFORE | AFTER } columnName ]
| ( { columnDefinition } [,...] ) }
Exemple
Dans cet exemple, nous allons ajouter une nouvelle colonne start_date à la table tutorials_tbl. Le type de données pour start_date est Date. Voici la requête pour ajouter une nouvelle colonne.
ALTER TABLE tutorials_tbl ADD start_date DATE;
La requête ci-dessus produit la sortie suivante.
(6) rows effected
Modifier la table Ajouter une contrainte
Alter table add constraint est une commande utilisée pour ajouter différentes contraintes à la table telles que la clé primaire, la clé étrangère, non nulle, etc.
Les index requis sont automatiquement créés s'ils n'existent pas encore. Il n'est pas possible de désactiver la vérification de la contrainte unique. Cette commande valide une transaction ouverte dans cette connexion.
Syntaxe
Voici la syntaxe générique de la commande Alter table add constraint.
ALTER TABLE [ IF EXISTS ] tableName ADD constraint [ CHECK | NOCHECK ]
Exemple
Dans cet exemple, ajoutons une contrainte de clé primaire (tutorials_tbl_pk) à l'ID de colonne de la table tutorials_tbl, en utilisant la requête suivante.
ALTER TABLE tutorials_tbl ADD CONSTRAINT tutorials_tbl_pk PRIMARYKEY(id);
La requête ci-dessus produit la sortie suivante.
(6) row (s) effected
Modifier la contrainte de changement de nom de table
Cette commande est utilisée pour renommer le nom de contrainte d'une table de relations particulière. Cette commande valide une transaction ouverte dans cette connexion.
Syntaxe
Voici la syntaxe générique de la commande Alter Table Rename Constraint.
ALTER TABLE [ IF EXISTS ] tableName RENAME oldConstraintName TO newConstraintName
Lors de l'utilisation de cette syntaxe, assurez-vous que l'ancien nom de contrainte doit exister avec la colonne correspondante.
Exemple
Dans cet exemple, nous allons changer le nom de la contrainte de clé primaire de la table tutorials_tbl de tutorials_tbl_pk à tutorials_tbl_pk_constraint. Voici la requête pour le faire.
ALTER TABLE tutorials_tbl RENAME CONSTRAINT
tutorials_tbl_pk TO tutorials_tbl_pk_constraint;
La requête ci-dessus produit la sortie suivante.
(1) row (s) effected
Modifier la table Modifier la colonne
Cette commande est utilisée pour modifier la structure et les propriétés de la colonne d'une table particulière. Changer les propriétés signifie changer le type de données d'une colonne, renommer une colonne, changer la valeur d'identité ou changer la sélectivité.
Syntaxe
Voici la syntaxe générique de la commande Alter Table Alter Column.
ALTER TABLE [ IF EXISTS ] tableName ALTER COLUMN columnName
{ { dataType [ DEFAULT expression ] [ [ NOT ] NULL ] [ AUTO_INCREMENT | IDENTITY ] }
| { RENAME TO name }
| { RESTART WITH long }
| { SELECTIVITY int }
| { SET DEFAULT expression }
| { SET NULL }
| { SET NOT NULL } }
Dans la syntaxe ci-dessus -
RESTART - La commande change la valeur suivante d'une colonne à incrémentation automatique.
SELECTIVITY- La commande définit la sélectivité (1-100) pour une colonne. Sur la base de la valeur de sélectivité, nous pouvons représenter la valeur de la colonne.
SET DEFAULT - modifie la valeur par défaut d'une colonne.
SET NULL - définit la colonne pour autoriser NULL.
SET NOT NULL - définit la colonne pour autoriser NOT NULL.
Exemple
Dans cet exemple, nous renommerons la colonne du tableau tutorials_tbl de Title à Tutorial_Title en utilisant la requête suivante.
ALTER TABLE tutorials_tbl ALTER COLUMN title RENAME TO tutorial_title;
La requête ci-dessus produit la sortie suivante.
(0) row(s) effected
De la même manière, nous pouvons effectuer différents scénarios avec la commande ALTER.
DROP est une commande tirée de la grammaire SQL générique. Cette commande est utilisée pour supprimer un composant de base de données et sa structure de la mémoire. Il existe différents scénarios avec la commande Drop dont nous parlerons dans ce chapitre.
Table de dépôt
Drop Table est une commande qui supprime la table respective et sa structure.
Syntaxe
Voici la syntaxe générique de la commande Drop Table.
DROP TABLE [ IF EXISTS ] tableName [,...] [ RESTRICT | CASCADE ]
La commande échouera si nous utilisons RESTRICT et la table ayant des vues dépendantes existe. Toutes les vues dépendantes sont supprimées lorsque nous utilisons le mot clé CASCADE.
Exemple
Dans cet exemple, nous allons supprimer une table nommée test à l'aide de la requête suivante.
DROP TABLE test;
La requête ci-dessus produit la sortie suivante.
(6) row (s) effected
Supprimer le schéma
Drop Schema est une commande qui supprime un schéma respectif du serveur de base de données. Cela ne fonctionnera pas à partir du schéma actuel.
Syntaxe
DROP SCHEMA [ IF EXISTS ] schemaName
Exemple
Dans cet exemple, nous allons supprimer un schéma nommé test_schema en utilisant la requête suivante.
DROP SCHEMA TEST_SCHEMA;
La requête ci-dessus produit la sortie suivante.
(0) row(s) effected
Séquence de dépôt
Drop Sequence est une commande utilisée pour supprimer une séquence de la structure de la table.
Syntax
Following is the generic syntax of the Drop Sequence command.
DROP SEQUENCE [ IF EXISTS ] sequenceName
This command commits an open transaction in this connection.
Example
In this example, we will drop a sequence named sequence_id. Following is the command.
DROP SEQUENCE sequence_id;
The above command produces the following output.
(0) row (s) effected
Drop View
Drop View is a command used to drop the existing view. All dependent views are dropped as well if the CASCADE clause is used.
Syntax
Following is the generic syntax of the Drop View command.
DROP VIEW [ IF EXISTS ] viewName [ RESTRICT | CASCADE ]
Example
In this example, we will drop a view named sample_view using the following query.
DROP VIEW sample_view;
The above query produces the following output.
(0) row (s) effected
TRUNCATE is a command used to delete the data from the table. Unlike DELETE FROM without WHERE clause, this command cannot be rolled back. This command commits an open transaction in this connection.
Syntax
Following is the generic syntax of the truncate command.
TRUNCATE TABLE tableName
Example
In this example, we will truncate a table named test using the following query.
TRUNCATE TABLE test;
The above query produces the following output.
(6) row (s) effected
COMMIT is a command from the SQL grammar used to commit the transaction. We can either commit the specific transaction or we can commit the currently executed transaction.
Syntax
There are two different syntaxes for COMMIT command.
Following is the generic syntax for the commit command to commit the current transaction.
COMMIT [ WORK ]
Following is the generic syntax for the commit command to commit the specific transaction.
COMMIT TRANSACTION transactionName
Example 1
In this example, let us commit the current transaction using the following command.
COMMIT
The above command produces the following output.
Committed successfully
Example 2
In this example, we will commit the transaction named tx_test using the following command.
COMMIT TRANSACTION tx_test;
The above command produces the following output.
Committed successfully
Grant is a command coming from the SQL grammar used to grant the rights to a table, to a user, or to a role. Admin rights are required to execute this command. This command commits an open transaction in this connection.
In this chapter, we will discuss the different scenarios of Grant command.
Grant Right
Grant Right is a command to provide admin rights to a table, to a user, or to a role.
Syntax
Following is the generic syntax of the Grant command.
GRANT { SELECT | INSERT | UPDATE | DELETE | ALL } [,...] ON
{ { SCHEMA schemaName } | { tableName [,...] } }
TO { PUBLIC | userName | roleName }
Example
In this example, we will grant the test table as read-only using the following command.
GRANT SELECT ON TEST TO READONLY
The above command produces the following output.
Grant successfully
Grant Alter Any Schema
Grant Alter Any Schema is a command to grant schema altering rights to a respective user.
Syntax
Following is the generic syntax of the Grant Alter Any Schema command.
GRANT ALTER ANY SCHEMA TO userName
Example
In this example, we will grant altering privileges of a schema to a user named test_user. Make sure that test_user exists. Following is the query to grant altering privileges.
GRANT ALTER ANY SCHEMA TO test_user;
The above query produces the following output.
Granted successfully to test_user
SAVEPOINT is a command used to temporarily save the transaction. It is better to maintain savepoints in your transaction as it is helpful to roll back the transaction to the respective Savepoint whenever necessary.
Syntax
Following is the generic syntax of the Savepoint command.
SAVEPOINT savepointName
Example
In this example, we will create a Savepoint named Half_Done using the following command.
SAVEPOINT Half_Done;
The above command produces the following output.
Savepoint created
ROLLBACK is a command from the SQL grammar used to roll back the transaction to a Savepoint or to the previous transaction. By using this command, we can either roll back to the specific Savepoint or we can roll back to the previous executed transaction.
Syntax
There are two different syntaxes for ROLLABCK command.
Following is the generic syntax for the rollback command.
ROLLBACK [ TO SAVEPOINT savepointName ]
Following is the generic syntax of the Rollback command to the specific transaction.
ROLLBACK TRANSACTION transactionName
Example 1
In this example, we will roll back the current transaction to a Savepoint named sp1_test using the following command.
ROLLBACK sp1_test;
The above command produces the following output.
Rollback successfully
Example 2
In the following example, we will roll back the complete transaction named tx_test using the given command.
ROLLBACK TRANSACTION tx_test;
The above command produces the following output.
Rollback successfully
H2 is a JAVA database. We can interact with this database by using JDBC. In this chapter, we will see how to create a JDBC connection with H2 database and the CRUD operations with the H2 database.
Generally, there are five steps to create a JDBC connection.
Step 1 − Registering the JDBC database driver.
Class.forName ("org.h2.Driver");
Step 2 − Opening the connection.
Connection conn = DriverManager.getConnection ("jdbc:h2:~/test", "sa","");
Step 3 − Creating a statement.
Statement st = conn.createStatement();
Step 4 − Executing a statement and receiving Resultset.
Stmt.executeUpdate("sql statement");
Step 5 − Closing a connection.
conn.close();
Before moving on to create a full program, we need to add h2-1.4.192.jar file to CLASSPATH. We can get this jar from the folder C:\Program Files (x86)\H2\bin.
Create Table
In this example, we will write a program for create table. Consider a table named Registration having the following fields.
S.No | Column Name | Data Type | NOT NULL | Primary Key |
---|---|---|---|---|
1 | ID | Number | Yes | Yes |
2 | First | Varchar(255) | No | No |
3 | Last | Varchar(255) | No | No |
4 | Age | Number | No | No |
Following is an example program named H2jdbcCreateDemo.
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.sql.Statement;
public class H2jdbcCreateDemo {
// JDBC driver name and database URL
static final String JDBC_DRIVER = "org.h2.Driver";
static final String DB_URL = "jdbc:h2:~/test";
// Database credentials
static final String USER = "sa";
static final String PASS = "";
public static void main(String[] args) {
Connection conn = null;
Statement stmt = null;
try {
// STEP 1: Register JDBC driver
Class.forName(JDBC_DRIVER);
//STEP 2: Open a connection
System.out.println("Connecting to database...");
conn = DriverManager.getConnection(DB_URL,USER,PASS);
//STEP 3: Execute a query
System.out.println("Creating table in given database...");
stmt = conn.createStatement();
String sql = "CREATE TABLE REGISTRATION " +
"(id INTEGER not NULL, " +
" first VARCHAR(255), " +
" last VARCHAR(255), " +
" age INTEGER, " +
" PRIMARY KEY ( id ))";
stmt.executeUpdate(sql);
System.out.println("Created table in given database...");
// STEP 4: Clean-up environment
stmt.close();
conn.close();
} catch(SQLException se) {
//Handle errors for JDBC
se.printStackTrace();
} catch(Exception e) {
//Handle errors for Class.forName
e.printStackTrace();
} finally {
//finally block used to close resources
try{
if(stmt!=null) stmt.close();
} catch(SQLException se2) {
} // nothing we can do
try {
if(conn!=null) conn.close();
} catch(SQLException se){
se.printStackTrace();
} //end finally try
} //end try
System.out.println("Goodbye!");
}
}
Save the above program into H2jdbcCreateDemo.java. Compile and execute the above program by executing the following commands in the command prompt.
\>javac H2jdbcCreateDemo.java
\>java H2jdbcCreateDemo
The above command produces the following output.
Connecting to database...
Creating table in given database...
Created table in given database...
Goodbye!
After this execution, we can check the table created using the H2 SQL interface.
Insert Records
In this example, we will write a program for inserting records. Let us insert the following records into the table Registration.
ID | First | Last | Age |
---|---|---|---|
100 | Zara | Ali | 18 |
101 | Mahnaz | Fatma | 25 |
102 | Zaid | Khan | 30 |
103 | Sumit | Mital | 28 |
Following is an example program named H2jdbcInsertDemo.
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.sql.Statement;
public class H2jdbcInsertDemo {
// JDBC driver name and database URL
static final String JDBC_DRIVER = "org.h2.Driver";
static final String DB_URL = "jdbc:h2:~/test";
// Database credentials
static final String USER = "sa";
static final String PASS = "";
public static void main(String[] args) {
Connection conn = null;
Statement stmt = null;
try{
// STEP 1: Register JDBC driver
Class.forName(JDBC_DRIVER);
// STEP 2: Open a connection
System.out.println("Connecting to a selected database...");
conn = DriverManager.getConnection(DB_URL,USER,PASS);
System.out.println("Connected database successfully...");
// STEP 3: Execute a query
stmt = conn.createStatement();
String sql = "INSERT INTO Registration " + "VALUES (100, 'Zara', 'Ali', 18)";
stmt.executeUpdate(sql);
sql = "INSERT INTO Registration " + "VALUES (101, 'Mahnaz', 'Fatma', 25)";
stmt.executeUpdate(sql);
sql = "INSERT INTO Registration " + "VALUES (102, 'Zaid', 'Khan', 30)";
stmt.executeUpdate(sql);
sql = "INSERT INTO Registration " + "VALUES(103, 'Sumit', 'Mittal', 28)";
stmt.executeUpdate(sql);
System.out.println("Inserted records into the table...");
// STEP 4: Clean-up environment
stmt.close();
conn.close();
} catch(SQLException se) {
// Handle errors for JDBC
se.printStackTrace();
} catch(Exception e) {
// Handle errors for Class.forName
e.printStackTrace();
} finally {
// finally block used to close resources
try {
if(stmt!=null) stmt.close();
} catch(SQLException se2) {
} // nothing we can do
try {
if(conn!=null) conn.close();
} catch(SQLException se) {
se.printStackTrace();
} // end finally try
} // end try
System.out.println("Goodbye!");
}
}
Save the above program into H2jdbcInsertDemo.java. Compile and execute the above program by executing the following commands in the command prompt.
\>javac H2jdbcInsertDemo.java
\>java H2jdbcInsertDemo
La commande ci-dessus produit la sortie suivante.
Connecting to a selected database...
Connected database successfully...
Inserted records into the table...
Goodbye!
Lire l'enregistrement
Dans cet exemple, nous allons écrire un programme de lecture d'enregistrements. Essayons de lire tous les enregistrements de la tableRegistration.
Voici un exemple de programme nommé H2jdbcRecordDemo.
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
public class H2jdbcReadDemo {
// JDBC driver name and database URL
static final String JDBC_DRIVER = "org.h2.Driver";
static final String DB_URL = "jdbc:h2:~/test";
// Database credentials
static final String USER = "sa";
static final String PASS = "";
public static void main(String[] args) {
Connection conn = null;
Statement stmt = null;
try {
// STEP 1: Register JDBC driver
Class.forName(JDBC_DRIVER);
// STEP 2: Open a connection
System.out.println("Connecting to database...");
conn = DriverManager.getConnection(DB_URL,USER,PASS);
// STEP 3: Execute a query
System.out.println("Connected database successfully...");
stmt = conn.createStatement();
String sql = "SELECT id, first, last, age FROM Registration";
ResultSet rs = stmt.executeQuery(sql);
// STEP 4: Extract data from result set
while(rs.next()) {
// Retrieve by column name
int id = rs.getInt("id");
int age = rs.getInt("age");
String first = rs.getString("first");
String last = rs.getString("last");
// Display values
System.out.print("ID: " + id);
System.out.print(", Age: " + age);
System.out.print(", First: " + first);
System.out.println(", Last: " + last);
}
// STEP 5: Clean-up environment
rs.close();
} catch(SQLException se) {
// Handle errors for JDBC
se.printStackTrace();
} catch(Exception e) {
// Handle errors for Class.forName
e.printStackTrace();
} finally {
// finally block used to close resources
try {
if(stmt!=null) stmt.close();
} catch(SQLException se2) {
} // nothing we can do
try {
if(conn!=null) conn.close();
} catch(SQLException se) {
se.printStackTrace();
} // end finally try
} // end try
System.out.println("Goodbye!");
}
}
Enregistrez le programme ci-dessus dans H2jdbcReadDemo.java. Compilez et exécutez le programme ci-dessus en exécutant les commandes suivantes dans l'invite de commande.
\>javac H2jdbcReadDemo.java
\>java H2jdbcReadDemo
La commande ci-dessus produit la sortie suivante.
Connecting to a selected database...
Connected database successfully...
ID: 100, Age: 18, First: Zara, Last: Ali
ID: 101, Age: 25, First: Mahnaz, Last: Fatma
ID: 102, Age: 30, First: Zaid, Last: Khan
ID: 103, Age: 28, First: Sumit, Last: Mittal
Goodbye!
Mettre à jour les enregistrements
Dans cet exemple, nous allons écrire un programme pour mettre à jour les enregistrements. Essayons de lire tous les enregistrements de la tableRegistration.
Voici un exemple de programme nommé H2jdbcUpdateDemo.
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
public class H2jdbcUpdateDemo {
// JDBC driver name and database URL
static final String JDBC_DRIVER = "org.h2.Driver";
static final String DB_URL = "jdbc:h2:~/test";
// Database credentials
static final String USER = "sa";
static final String PASS = "";
public static void main(String[] args) {
Connection conn = null;
Statement stmt = null;
try {
// STEP 1: Register JDBC driver
Class.forName(JDBC_DRIVER);
// STEP 2: Open a connection
System.out.println("Connecting to a database...");
conn = DriverManager.getConnection(DB_URL,USER,PASS);
// STEP 3: Execute a query
System.out.println("Connected database successfully...");
stmt = conn.createStatement();
String sql = "UPDATE Registration " + "SET age = 30 WHERE id in (100, 101)";
stmt.executeUpdate(sql);
// Now you can extract all the records
// to see the updated records
sql = "SELECT id, first, last, age FROM Registration";
ResultSet rs = stmt.executeQuery(sql);
while(rs.next()){
// Retrieve by column name
int id = rs.getInt("id");
int age = rs.getInt("age");
String first = rs.getString("first");
String last = rs.getString("last");
// Display values
System.out.print("ID: " + id);
System.out.print(", Age: " + age);
System.out.print(", First: " + first);
System.out.println(", Last: " + last);
}
rs.close();
} catch(SQLException se) {
// Handle errors for JDBC
se.printStackTrace();
} catch(Exception e) {
// Handle errors for Class.forName
e.printStackTrace();
} finally {
// finally block used to close resources
try {
if(stmt!=null) stmt.close();
} catch(SQLException se2) {
} // nothing we can do
try {
if(conn!=null) conn.close();
} catch(SQLException se) {
se.printStackTrace();
} // end finally try
} // end try
System.out.println("Goodbye!");
}
}
Enregistrez le programme ci-dessus dans H2jdbcUpdateDemo.java. Compilez et exécutez le programme ci-dessus en exécutant les commandes suivantes dans l'invite de commande.
\>javac H2jdbcUpdateDemo.java
\>java H2jdbcUpdateDemo
La commande ci-dessus produit la sortie suivante.
Connecting to a selected database...
Connected database successfully...
ID: 100, Age: 30, First: Zara, Last: Ali
ID: 101, Age: 30, First: Mahnaz, Last: Fatma
ID: 102, Age: 30, First: Zaid, Last: Khan
ID: 103, Age: 28, First: Sumit, Last: Mittal
Goodbye!
Supprimer des enregistrements
Dans cet exemple, nous allons écrire un programme pour supprimer des enregistrements. Essayons de lire tous les enregistrements de la tableRegistration.
Voici un exemple de programme nommé H2jdbcDeleteDemo.
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
public class H2jdbcDeleteDemo {
// JDBC driver name and database URL
static final String JDBC_DRIVER = "org.h2.Driver";
static final String DB_URL = "jdbc:h2:~/test";
// Database credentials
static final String USER = "sa";
static final String PASS = "";
public static void main(String[] args) {
Connection conn = null;
Statement stmt = null;
try {
// STEP 1: Register JDBC driver
Class.forName(JDBC_DRIVER);
// STEP 2: Open a connection
System.out.println("Connecting to database...");
conn = DriverManager.getConnection(DB_URL,USER,PASS);
// STEP 3: Execute a query
System.out.println("Creating table in given database...");
stmt = conn.createStatement();
String sql = "DELETE FROM Registration " + "WHERE id = 101";
stmt.executeUpdate(sql);
// Now you can extract all the records
// to see the remaining records
sql = "SELECT id, first, last, age FROM Registration";
ResultSet rs = stmt.executeQuery(sql);
while(rs.next()){
// Retrieve by column name
int id = rs.getInt("id");
int age = rs.getInt("age");
String first = rs.getString("first");
String last = rs.getString("last");
// Display values
System.out.print("ID: " + id);
System.out.print(", Age: " + age);
System.out.print(", First: " + first);
System.out.println(", Last: " + last);
}
rs.close();
} catch(SQLException se) {
// Handle errors for JDBC
se.printStackTrace();
} catch(Exception e) {
// Handle errors for Class.forName
e.printStackTrace();
} finally {
// finally block used to close resources
try {
if(stmt!=null) stmt.close();
} catch(SQLException se2) {
} // nothing we can do
try {
if(conn!=null) conn.close();
} catch(SQLException se) {
se.printStackTrace();
} // end finally try
} // end try
System.out.println("Goodbye!");
}
}
Enregistrez le programme ci-dessus dans H2jdbcDeleteDemo.java. Compilez et exécutez le programme ci-dessus en exécutant les commandes suivantes dans l'invite de commande.
\>javac H2jdbcDeleteDemo.java
\>java H2jdbcDeleteDemo
La commande ci-dessus produit la sortie suivante.
Connecting to a selected database...
Connected database successfully...
ID: 100, Age: 30, First: Zara, Last: Ali
ID: 102, Age: 30, First: Zaid, Last: Khan
ID: 103, Age: 28, First: Sumit, Last: Mittal
Goodbye!