Cassandra - Lire les données

Lecture des données à l'aide de la clause Select

La clause SELECT est utilisée pour lire les données d'une table dans Cassandra. En utilisant cette clause, vous pouvez lire une table entière, une seule colonne ou une cellule particulière. Voici la syntaxe de la clause SELECT.

SELECT FROM <tablename>

Exemple

Supposons qu'il existe une table dans l'espace de clés nommé emp avec les détails suivants -

emp_id nom_emp emp_city emp_phone emp_sal
1 RAM Hyderabad 9848022338 50000
2 merle nul 9848022339 50000
3 rahman Chennai 9848022330 50000
4 Rajeev Pune 9848022331 30000

L'exemple suivant montre comment lire une table entière à l'aide de la clause SELECT. Ici, nous lisons un tableau appeléemp.

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)

Lecture des colonnes requises

L'exemple suivant montre comment lire une colonne particulière dans une table.

cqlsh:tutorialspoint> SELECT emp_name, emp_sal from emp;

 emp_name | emp_sal
----------+---------
      ram | 50000
    robin | 50000
   rajeev | 30000
   rahman | 50000 
	
(4 rows)

Clause Où

En utilisant la clause WHERE, vous pouvez mettre une contrainte sur les colonnes requises. Sa syntaxe est la suivante -

SELECT FROM <table name> WHERE <condition>;

Note - Une clause WHERE ne peut être utilisée que sur les colonnes faisant partie de la clé primaire ou comportant un index secondaire.

Dans l'exemple suivant, nous lisons les détails d'un employé dont le salaire est de 50000. Tout d'abord, définissez l'index secondaire sur la colonne emp_sal.

cqlsh:tutorialspoint> CREATE INDEX ON emp(emp_sal);
cqlsh:tutorialspoint> SELECT * FROM emp WHERE emp_sal=50000;

 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

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

Vous pouvez lire les données d'une table en utilisant 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 avez déjà un espace de clés, vous pouvez le définir sur celui existant en passant 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 cet exemple, nous récupérons les données de emptable. Stockez la requête dans une chaîne et transmettez-la à la méthode execute () de la classe de session comme indiqué ci-dessous.

String query = ”SELECT 8 FROM emp”;
session.execute(query);

Exécutez la requête à l'aide de la méthode execute () de la classe Session.

Étape 4: Obtenez l'objet ResultSet

Les requêtes de sélection renverront le résultat sous la forme d'un ResultSet objet, stockez donc le résultat dans l'objet de RESULTSET classe comme indiqué ci-dessous.

ResultSet result = session.execute( );

Ci-dessous est le programme complet pour lire les données d'une table.

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

public class Read_Data {

   public static void main(String args[])throws Exception{
    
      //queries
      String query = "SELECT * FROM emp";

      //Creating Cluster object
      Cluster cluster = Cluster.builder().addContactPoint("127.0.0.1").build();
    
      //Creating Session object
      Session session = cluster.connect("tutorialspoint");
    
      //Getting the ResultSet
      ResultSet result = session.execute(query);
    
      System.out.println(result.all());
   }
}

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

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

[Row[1, Hyderabad, ram, 9848022338, 50000], Row[2, Delhi, robin,
9848022339, 50000], Row[4, Pune, rajeev, 9848022331, 30000], Row[3,
Chennai, rahman, 9848022330, 50000]]