Cassandra - Relevés de lots
Utilisation des instructions Batch
En utilisant BATCH,vous pouvez exécuter plusieurs instructions de modification (insérer, mettre à jour, supprimer) simultanément. Sa syntaxe est la suivante -
BEGIN BATCH
<insert-stmt>/ <update-stmt>/ <delete-stmt>
APPLY BATCH
Exemple
Supposons qu'il existe une table dans Cassandra appelée emp contenant les données suivantes -
emp_id | nom_emp | emp_city | emp_phone | emp_sal |
---|---|---|---|---|
1 | RAM | Hyderabad | 9848022338 | 50000 |
2 | merle | Delhi | 9848022339 | 50000 |
3 | rahman | Chennai | 9848022330 | 45 000 |
Dans cet exemple, nous allons effectuer les opérations suivantes -
- Insérez une nouvelle ligne avec les détails suivants (4, rajeev, pune, 9848022331, 30000).
- Mettez à jour le salaire de l'employé avec l'ID de ligne 3 à 50000.
- Supprimer la ville de l'employé avec l'ID de ligne 2.
Pour effectuer les opérations ci-dessus en une seule fois, utilisez la commande BATCH suivante -
cqlsh:tutorialspoint> BEGIN BATCH
... INSERT INTO emp (emp_id, emp_city, emp_name, emp_phone, emp_sal) values( 4,'Pune','rajeev',9848022331, 30000);
... UPDATE emp SET emp_sal = 50000 WHERE emp_id =3;
... DELETE emp_city FROM emp WHERE emp_id = 2;
... APPLY BATCH;
Vérification
Après avoir apporté des modifications, vérifiez la table à l'aide de l'instruction SELECT. Il devrait produire la sortie suivante -
cqlsh:tutorialspoint> select * from emp;
emp_id | emp_city | emp_name | emp_phone | emp_sal
--------+-----------+----------+------------+---------
1 | Hyderabad | ram | 9848022338 | 50000
2 | null | robin | 9848022339 | 50000
3 | Chennai | rahman | 9848022330 | 50000
4 | Pune | rajeev | 9848022331 | 30000
(4 rows)
Ici, vous pouvez observer le tableau avec des données modifiées.
Instructions par lots à l'aide de l'API Java
Les instructions Batch peuvent être écrites par programme dans une table à l'aide de la méthode execute () de la classe Session. Suivez les étapes ci-dessous pour exécuter plusieurs instructions à l'aide d'une instruction batch à l'aide de l'API Java.
Étape 1: créer un objet de cluster
Créer une instance de Cluster.builder une sorte de com.datastax.driver.core paquet comme indiqué ci-dessous.
//Creating Cluster.Builder object
Cluster.Builder builder1 = Cluster.builder();
Ajoutez un point de contact (adresse IP du nœud) à l'aide du addContactPoint() méthode de Cluster.Builderobjet. Cette méthode renvoieCluster.Builder.
//Adding contact point to the Cluster.Builder object
Cluster.Builder builder2 = build.addContactPoint( "127.0.0.1" );
À l'aide du nouvel objet de générateur, créez un objet de cluster. Pour ce faire, vous disposez d'une méthode appeléebuild() dans le Cluster.Builderclasse. Utilisez le code suivant pour créer l'objet de cluster -
//Building a cluster
Cluster cluster = builder.build();
Vous pouvez créer l'objet de cluster en utilisant une seule ligne de code comme indiqué ci-dessous.
Cluster cluster = Cluster.builder().addContactPoint("127.0.0.1").build();
Étape 2: créer un objet de session
Créez une instance de l'objet Session à l'aide de la méthode connect () de la classe Cluster comme indiqué ci-dessous.
Session session = cluster.connect( );
Cette méthode crée une nouvelle session et l'initialise. Si vous disposez déjà d'un espace de clés, vous pouvez le définir sur celui existant en transmettant le nom de l'espace de clé au format chaîne à cette méthode, comme indiqué ci-dessous.
Session session = cluster.connect(“ Your keyspace name ”);
Ici, nous utilisons le KeySpace nommé tp. Par conséquent, créez l'objet de session comme indiqué ci-dessous.
Session session = cluster.connect(“tp”);
Étape 3: Exécuter la requête
Vous pouvez exécuter des requêtes CQL en utilisant la méthode execute () de la classe Session. Transmettez la requête au format chaîne ou en tant qu'objet de classe Statement à la méthode execute (). Tout ce que vous passez à cette méthode au format chaîne sera exécuté sur lecqlsh.
Dans cet exemple, nous allons effectuer les opérations suivantes -
- Insérez une nouvelle ligne avec les détails suivants (4, rajeev, pune, 9848022331, 30000).
- Mettez à jour le salaire de l'employé avec l'ID de ligne 3 à 50000.
- Supprimez la ville de l'employé avec l'ID de ligne 2.
Vous devez stocker la requête dans une variable chaîne et la transmettre à la méthode execute () comme indiqué ci-dessous.
String query1 = ” BEGIN BATCH INSERT INTO emp (emp_id, emp_city, emp_name, emp_phone, emp_sal) values( 4,'Pune','rajeev',9848022331, 30000);
UPDATE emp SET emp_sal = 50000 WHERE emp_id =3;
DELETE emp_city FROM emp WHERE emp_id = 2;
APPLY BATCH;”;
Vous trouverez ci-dessous le programme complet pour exécuter plusieurs instructions simultanément sur une table dans Cassandra à l'aide de l'API Java.
import com.datastax.driver.core.Cluster;
import com.datastax.driver.core.Session;
public class Batch {
public static void main(String args[]){
//query
String query =" BEGIN BATCH INSERT INTO emp (emp_id, emp_city,
emp_name, emp_phone, emp_sal) values( 4,'Pune','rajeev',9848022331, 30000);"
+ "UPDATE emp SET emp_sal = 50000 WHERE emp_id =3;"
+ "DELETE emp_city FROM emp WHERE emp_id = 2;"
+ "APPLY BATCH;";
//Creating Cluster object
Cluster cluster = Cluster.builder().addContactPoint("127.0.0.1").build();
//Creating Session object
Session session = cluster.connect("tp");
//Executing the query
session.execute(query);
System.out.println("Changes done");
}
}
Enregistrez le programme ci-dessus avec le nom de la classe suivi de .java, accédez à l'emplacement où il est enregistré. Compilez et exécutez le programme comme indiqué ci-dessous.
$javac Batch.java $java Batch
Dans des conditions normales, il devrait produire la sortie suivante -
Changes done