Cassandra - Créer une table

Créer une table

Vous pouvez créer une table à l'aide de la commande CREATE TABLE. Vous trouverez ci-dessous la syntaxe pour créer une table.

Syntaxe

CREATE (TABLE | COLUMNFAMILY) <tablename>
('<column-definition>' , '<column-definition>')
(WITH <option> AND <option>)

Définition d'une colonne

Vous pouvez définir une colonne comme indiqué ci-dessous.

column name1 data type,
column name2 data type,

example:

age int,
name text

Clé primaire

La clé primaire est une colonne utilisée pour identifier de manière unique une ligne. Par conséquent, la définition d'une clé primaire est obligatoire lors de la création d'une table. Une clé primaire est constituée d'une ou plusieurs colonnes d'une table. Vous pouvez définir une clé primaire d'une table comme indiqué ci-dessous.

CREATE TABLE tablename(
   column1 name datatype PRIMARYKEY,
   column2 name data type,
   column3 name data type.
   )

or

CREATE TABLE tablename(
   column1 name datatype PRIMARYKEY,
   column2 name data type,
   column3 name data type,
   PRIMARY KEY (column1)
   )

Exemple

Vous trouverez ci-dessous un exemple pour créer une table dans Cassandra à l'aide de cqlsh. Nous voici -

  • Utilisation du point du didacticiel de l'espace de clés

  • Créer une table nommée emp

Il contiendra des détails tels que le nom de l'employé, l'identifiant, la ville, le salaire et le numéro de téléphone. L'identifiant d'employé est la clé primaire.

cqlsh> USE tutorialspoint;
cqlsh:tutorialspoint>; CREATE TABLE emp(
   emp_id int PRIMARY KEY,
   emp_name text,
   emp_city text,
   emp_sal varint,
   emp_phone varint
   );

Vérification

L'instruction select vous donnera le schéma. Vérifiez le tableau à l'aide de l'instruction select comme indiqué ci-dessous.

cqlsh:tutorialspoint> select * from emp;

 emp_id | emp_city | emp_name | emp_phone | emp_sal
--------+----------+----------+-----------+---------

(0 rows)

Ici vous pouvez observer le tableau créé avec les colonnes données. Puisque nous avons supprimé le point du didacticiel de l'espace de clés, vous ne le trouverez pas dans la liste des espaces de clés.

Création d'une table à l'aide de l'API Java

Vous pouvez créer une table en utilisant la méthode execute () de la classe Session. Suivez les étapes ci-dessous pour créer une table à l'aide de l'API Java.

Étape 1: créer un objet de cluster

Tout d'abord, créez une instance du 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. Le code suivant montre comment créer un objet de cluster.

//Building a cluster
Cluster cluster = builder.build();

Vous pouvez créer un 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 du connect() méthode de Cluster classe 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és au format chaîne à cette méthode, comme indiqué ci-dessous.

Session session = cluster.connect(“ Your keyspace name ” );

Ici, nous utilisons l'espace de clés 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 le cqlsh.

Dans l'exemple suivant, nous créons une table nommée emp. Vous devez stocker la requête dans une variable chaîne et la transmettre à la méthode execute () comme indiqué ci-dessous.

//Query
String query = "CREATE TABLE emp(emp_id int PRIMARY KEY, "
   + "emp_name text, "
   + "emp_city text, "
   + "emp_sal varint, "
   + "emp_phone varint );";
session.execute(query);

Vous trouverez ci-dessous le programme complet pour créer et utiliser un espace de clés dans Cassandra à l'aide de l'API Java.

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

public class Create_Table {

   public static void main(String args[]){

      //Query
      String query = "CREATE TABLE emp(emp_id int PRIMARY KEY, "
         + "emp_name text, "
         + "emp_city text, "
         + "emp_sal varint, "
         + "emp_phone varint );";
		
      //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("Table created");
   }
}

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

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

Table created