Cassandra - CQL 用户自定义数据类型


CQL 提供了创建和使用用户自定义数据类型的功能。您可以创建一个数据类型来处理多个字段。本章解释如何创建、修改和删除用户自定义数据类型。

创建用户自定义数据类型

命令 `CREATE TYPE` 用于创建用户自定义数据类型。其语法如下:

CREATE TYPE <keyspace name>. <data typename>
( variable1, variable2).

示例

下面是一个创建用户自定义数据类型的示例。在这个例子中,我们正在创建一个包含以下详细信息的 `card_details` 数据类型。

字段 字段名称 数据类型
信用卡号 num int
信用卡密码 pin int
信用卡持卡人姓名 name text
cvv cvv int
持卡人联系方式 phone set
cqlsh:tutorialspoint> CREATE TYPE card_details (
   ... num int,
   ... pin int,
   ... name text,
   ... cvv int,
   ... phone set<int>
... );

**注意** - 用户自定义数据类型使用的名称不应与保留类型名称冲突。

验证

使用 `DESCRIBE` 命令验证是否已创建该类型。

CREATE TYPE tutorialspoint.card_details (
   num int,
   pin int,
   name text,
   cvv int,
   phone set<int>
   );

修改用户自定义数据类型

`ALTER TYPE` 命令用于修改现有数据类型。使用 ALTER,您可以添加新字段或重命名现有字段。

向类型添加字段

使用以下语法向现有用户自定义数据类型添加新字段。

ALTER TYPE typename
ADD field_name field_type; 

以下代码向 `Card_details` 数据类型添加一个新字段。这里我们添加一个名为 email 的新字段。

cqlsh:tutorialspoint> ALTER TYPE card_details ADD email text;

验证

使用 `DESCRIBE` 命令验证是否已添加新字段。

cqlsh:tutorialspoint> describe type card_details;
CREATE TYPE tutorialspoint.card_details (
   num int,
   pin int,
   name text,
   cvv int,
   phone set<int>,
   );

重命名类型中的字段

使用以下语法重命名现有用户自定义数据类型。

ALTER TYPE typename
RENAME existing_name TO new_name;

以下代码更改类型中字段的名称。这里我们将字段 email 重命名为 mail。

cqlsh:tutorialspoint> ALTER TYPE card_details RENAME email TO mail;

验证

使用 `DESCRIBE` 命令验证类型名称是否已更改。

cqlsh:tutorialspoint> describe type card_details;
CREATE TYPE tutorialspoint.card_details (
   num int,
   pin int,
   name text,
   cvv int,
   phone set<int>,
   mail text
   );

删除用户自定义数据类型

`DROP TYPE` 是用于删除用户自定义数据类型的命令。下面是一个删除用户自定义数据类型的示例。

示例

在删除之前,使用 `DESCRIBE_TYPES` 命令验证所有用户自定义数据类型的列表,如下所示。

cqlsh:tutorialspoint> DESCRIBE TYPES;
card_details card

从这两种类型中,删除名为 `card` 的类型,如下所示。

cqlsh:tutorialspoint> drop type card;

使用 `DESCRIBE` 命令验证数据类型是否已删除。

cqlsh:tutorialspoint> describe types;

card_details
广告