Cassandra - Types de données définis par l'utilisateur CQL
CQL offre la possibilité de créer et d'utiliser des types de données définis par l'utilisateur. Vous pouvez créer un type de données pour gérer plusieurs champs. Ce chapitre explique comment créer, modifier et supprimer un type de données défini par l'utilisateur.
Création d'un type de données défini par l'utilisateur
La commande CREATE TYPEest utilisé pour créer un type de données défini par l'utilisateur. Sa syntaxe est la suivante -
CREATE TYPE <keyspace name>. <data typename>
( variable1, variable2).
Exemple
Vous trouverez ci-dessous un exemple de création d'un type de données défini par l'utilisateur. Dans cet exemple, nous créons uncard_details type de données contenant les détails suivants.
Champ | Nom de domaine | Type de données |
---|---|---|
carte de crédit non | num | int |
broche de carte de crédit | épingle | int |
Nom sur la carte de crédit | Nom | texte |
cvv | cvv | int |
Coordonnées du titulaire de la carte | téléphone | ensemble |
cqlsh:tutorialspoint> CREATE TYPE card_details (
... num int,
... pin int,
... name text,
... cvv int,
... phone set<int>
... );
Note - Le nom utilisé pour le type de données défini par l'utilisateur ne doit pas coïncider avec les noms de type réservés.
Vérification
Utilisez le DESCRIBE pour vérifier si le type créé a été créé ou non.
CREATE TYPE tutorialspoint.card_details (
num int,
pin int,
name text,
cvv int,
phone set<int>
);
Modification d'un type de données défini par l'utilisateur
ALTER TYPE- la commande est utilisée pour modifier un type de données existant. En utilisant ALTER, vous pouvez ajouter un nouveau champ ou renommer un champ existant.
Ajout d'un champ à un type
Utilisez la syntaxe suivante pour ajouter un nouveau champ à un type de données défini par l'utilisateur existant.
ALTER TYPE typename
ADD field_name field_type;
Le code suivant ajoute un nouveau champ au Card_detailsType de données. Ici, nous ajoutons un nouveau champ appelé email.
cqlsh:tutorialspoint> ALTER TYPE card_details ADD email text;
Vérification
Utilisez le DESCRIBE pour vérifier si le nouveau champ est ajouté ou non.
cqlsh:tutorialspoint> describe type card_details;
CREATE TYPE tutorialspoint.card_details (
num int,
pin int,
name text,
cvv int,
phone set<int>,
);
Renommer un champ dans un type
Utilisez la syntaxe suivante pour renommer un type de données défini par l'utilisateur existant.
ALTER TYPE typename
RENAME existing_name TO new_name;
Le code suivant modifie le nom du champ dans un type. Ici, nous renommons le champ email en mail.
cqlsh:tutorialspoint> ALTER TYPE card_details RENAME email TO mail;
Vérification
Utilisez le DESCRIBE pour vérifier si le nom du type a changé ou non.
cqlsh:tutorialspoint> describe type card_details;
CREATE TYPE tutorialspoint.card_details (
num int,
pin int,
name text,
cvv int,
phone set<int>,
mail text
);
Suppression d'un type de données défini par l'utilisateur
DROP TYPEest la commande utilisée pour supprimer un type de données défini par l'utilisateur. Vous trouverez ci-dessous un exemple de suppression d'un type de données défini par l'utilisateur.
Exemple
Avant de supprimer, vérifiez la liste de tous les types de données définis par l'utilisateur à l'aide de DESCRIBE_TYPES comme indiqué ci-dessous.
cqlsh:tutorialspoint> DESCRIBE TYPES;
card_details card
Parmi les deux types, supprimez le type nommé card comme indiqué ci-dessous.
cqlsh:tutorialspoint> drop type card;
Utilisez le DESCRIBE pour vérifier si le type de données a été supprimé ou non.
cqlsh:tutorialspoint> describe types;
card_details