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