Cassandra - Supprimer les données

Suppression de données d'une table

Vous pouvez supprimer des données d'une table à l'aide de la commande DELETE. Sa syntaxe est la suivante -

DELETE FROM <identifier> WHERE <condition>;

Exemple

Supposons qu'il existe une table à Cassandra appelée emp ayant les données suivantes -

emp_id nom_emp emp_city emp_phone emp_sal
1 RAM Hyderabad 9848022338 50000
2 merle Hyderabad 9848022339 40000
3 rahman Chennai 9848022330 45 000

L'instruction suivante supprime la colonne emp_sal de la dernière ligne -

cqlsh:tutorialspoint> DELETE emp_sal FROM emp WHERE emp_id=3;

Vérification

Utilisez l'instruction SELECT pour vérifier si les données ont été supprimées ou non. Si vous vérifiez la table emp en utilisant SELECT, elle produira la sortie suivante -

cqlsh:tutorialspoint> select * from emp;

 emp_id |  emp_city | emp_name |  emp_phone | emp_sal
--------+-----------+----------+------------+---------
      1 | Hyderabad |      ram | 9848022338 | 50000
      2 |     Delhi |    robin | 9848022339 | 50000
      3 |   Chennai |   rahman | 9848022330 | null
(3 rows)

Puisque nous avons supprimé le salaire de Rahman, vous observerez une valeur nulle à la place du salaire.

Supprimer une ligne entière

La commande suivante supprime une ligne entière d'une table.

cqlsh:tutorialspoint> DELETE FROM emp WHERE emp_id=3;

Vérification

Utilisez l'instruction SELECT pour vérifier si les données ont été supprimées ou non. Si vous vérifiez la table emp en utilisant SELECT, elle produira la sortie suivante -

cqlsh:tutorialspoint> select * from emp;

 emp_id |  emp_city | emp_name |  emp_phone | emp_sal
--------+-----------+----------+------------+---------
      1 | Hyderabad |      ram | 9848022338 | 50000
      2 |     Delhi |    robin | 9848022339 | 50000
 
(2 rows)

Depuis que nous avons supprimé la dernière ligne, il ne reste plus que deux lignes dans le tableau.

Suppression de données à l'aide de l'API Java

Vous pouvez supprimer des données dans une table à l'aide de la méthode execute () de la classe Session. Suivez les étapes ci-dessous pour supprimer des données d'une table à 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 un 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 avez déjà 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 appelé 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 l'exemple suivant, nous supprimons des données d'une table nommée emp. Vous devez stocker la requête dans une variable chaîne et la transmettre au execute() méthode comme indiqué ci-dessous.

String query1 = ”DELETE FROM emp WHERE emp_id=3; ”;
session.execute(query);

Vous trouverez ci-dessous le programme complet pour supprimer des données d'une table dans Cassandra à l'aide de l'API Java.

import com.datastax.driver.core.Cluster;
import com.datastax.driver.core.Session;

public class Delete_Data {

   public static void main(String args[]){
   
      //query
      String query = "DELETE FROM emp WHERE emp_id=3;";

      //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("Data deleted");
   }
}

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 Delete_Data.java
$java Delete_Data

Dans des conditions normales, il devrait produire la sortie suivante -

Data deleted