Apache Cassandra 中的集合数据类型
我们将在 Cassandra 之旅中查看 Cassandra 集合数据类型教程。在此,我们将了解 Cassandra 的集合数据类型。这些数据类型与 C、C++ 等中的数组和结构意义相同。
此外,我们将使用列表、集合和映射讨论 Cassandra 集合数据类型。
因此,让我们从 Cassandra 集合数据类型开始。
Cassandra 的集合数据类型
在 Cassandra 中,集合数据类型本质上是多个值的存储容器。通常,Cassandra-CQL 集合数据类型由单个变量定义。此变量本身具有一系列值。
列表、集合和映射是几种集合数据类型。在这些 Cassandra 集合数据类型上,执行了许多操作。其中包括创建、插入、更新和验证操作。
a)Cassandra 列表
此数据类型的值以列表形式保存。此列表包含单个值的多个副本。对于列表数据类型,只有一个规则。
元素不能按顺序修改。将值存储在列表中后,将为元素赋予特定索引。这些索引可用于获取值。
i) 创建表
在 Cassandra 中,个人可以使用 CREATE TABLE 命令创建具有列表数据类型的表。表中可能有许多列。表创建语法是。
cqlsh:<keyspace>>CREATE TABLE <table name>(column1 PRIMARY KEY,column2 list <data type>,column3 list <data type>,.....);
构建一个包含"大学生"列名、学号和科系的表。
cqlsh> USE keyspace1; cqlsh:keyspace1> CREATE TABLE employee ... (EN int, ... NAME text, ... EMAIL LIST, ... PRIMARY KEY(EN), ... );
输出
EN |
NAME |
|
---|---|---|
|
|
|
ii) 插入
用户可以使用 INSERT INTO 命令将组件添加到表中。方括号中包含的每个值都用逗号分隔。语法是 −
cqlsh:<keyspace>> INSERT INTO <table name>(column1, column2, column3,....) VALUES('R1value1',['R1value1','R1value2','R1value3'...]['R1value11','R1value12','R1value13'...]...);
示例
cqlsh:keyspace1> INSERT INTO college student (EN, NAME, EMAIL) ... VALUES(001,'hardik',{'hardi@gmail.com'}); cqlsh:keyspace1> INSERT INTO college student (EN, NAME, EMAIL) ... VALUES(002,'Ajites',{'ajit@mail.com'}); cqlsh:keyspace1> INSERT INTO college student (EN, NAME, EMAIL) ... VALUES(003,'Pushpa',{'tears@mail.com'});
输出
EN |
NAME |
|
---|---|---|
001 |
hardik |
hardi@gmail.com |
002 |
Ajites |
ajit@mail.com |
003 |
Pushpa |
tears@mail.com |
iii) 更新
Cassandra 的 UPDATE 命令用于更新某些表列的值。更新语法如下。
cqlsh:<keyspace> UPDATE<table name> SET <column2>=<column2>+['value'] where <column1>='some value';
示例
cqlsh:keyspace2>UPDATE college student SET EMAIL=EMAIL+['hardikgupta.1@gmail.com'] where EN=001;
输出
EN |
NAME |
|
---|---|---|
001 |
hardik |
hardikgupta.1@gmail.com |
002 |
Ajites |
ajit@mail.com |
003 |
Pushpa |
tears@mail.com |
b) Cassandra Set
用户可以使用 SET Cassandra 集合数据类型来存储元素集合。执行后,集合的组件将以排序的方式返回。
i. 创建表
用户可以使用 Construct 命令和以下语法来创建包含该集合的表。
cqlsh:<keyspace> CREATE TABLE<table name> (column1 PRIMARY KEY, column2 set <data type>, column3 set <data type>.....);
示例
构建一个包含"大学生"姓名、学号、所属科系等列的表格。
cqlsh> USE keyspace2; cqlsh:keyspace2> CREATE TABLE employee ... (EN int, ... NAME text, ... EMAIL LIST<text>, ... PRIMARY KEY(EN), ... );
输出
EN |
NAME |
|
---|---|---|
|
|
|
ii. Cassandra Insert
INSERT INTO 命令与以下语法结合使用,可将值插入集合中。
cqlsh:<keyspace>> INSERT INTO <table name>(column1, column2, column3...) VALUES('R1value',{'R1value1', 'R1value2',..},{ 'R1value11', 'R1value12',..}....);
示例
> cqlsh:keyspace2> INSERT INTO college student (EN, NAME, EMAIL) ... VALUES(001,'hardik',{'hardi@gmail.com'}); cqlsh:keyspace2> INSERT INTO college student (EN, NAME, EMAIL) ... VALUES(002,'Ajites',{'ajit@mail.com'}); cqlsh:keyspace2> INSERT INTO college student (EN, NAME, EMAIL) ... VALUES(003,'Pushpa',{'tears@mail.com'});
输出
EN |
NAME |
|
---|---|---|
001 |
hardik |
hardi@gmail.com |
002 |
Ajites |
ajit@mail.com |
003 |
Pushpa |
tears@mail.com |
iii. Cassandra UPDATE
用户可以使用此语法更新集合中的内容。
cqlsh:<keyspace>>UPDATE <table name> SET <column2>=<column2>+['value'] where <column1>='some value';
示例
cqlsh:keyspace2>UPDATE college student SET EMAIL=EMAIL+['hardikgupta.1@gmail.com'] where EN=001;
输出
EN |
NAME |
|
---|---|---|
001 |
hardik |
hardikgupta.1@gmail.com |
002 |
Ajites |
ajit@mail.com |
003 |
Pushpa |
tears@mail.com |
c)Cassandra 映射
一对键值项存储在一个 Map 中,这是 Cassandra 集合数据类型。
i. 创建表
用户可以使用以下语法的 Construct 命令创建带有 Map 的表。
cqlsh:<keyspace> CREATE TABLE<table name> (column1 PRIMARY KEY, column2 map <type, data type>, column3 map <type, data type>.....);
Constructing a table with the columns name, enrollment number, and branch for "college students."
cqlsh> USE keyspace3; cqlsh:keyspace3> CREATE TABLE employee ... (EN int, ... NAME text, ... EMAIL LIST, ... PRIMARY KEY(EN), ... );
输出
EN |
NAME |
|
---|---|---|
|
|
|
ii. 插入
INSERT INTO 命令与以下语法结合使用,可将值插入映射。
cqlsh:<keyspace>> INSERT INTO <table name>(column1, column2, column3...) VALUES('R1value',{'R1value1':'R1value1' ,R1value2:'R1value01',..},{ 'R1value11':'R1value011','R1value12':'R1value012',..}....);
示例
cqlsh:keyspace3> INSERT INTO college student (EN, NAME, EMAIL) ... VALUES(001,'hardik',{'hardi@gmail.com'}); cqlsh:keyspace3> INSERT INTO college student (EN, NAME, EMAIL) ... VALUES(002,'Ajites',{'ajit@mail.com'}); cqlsh:keyspace3> INSERT INTO college student (EN, NAME, EMAIL) ... VALUES(003,'Pushpa',{'tears@mail.com'});
输出
EN |
NAME |
|
---|---|---|
001 |
hardik |
hardi@gmail.com |
002 |
Ajites |
ajit@mail.com |
003 |
Pushpa |
tears@mail.com |
iii. 更新
使用此技术,用户可以修改集合的内容。
cqlsh:<keyspace>>UPDATE <table name> SET <column2>=<column2>+['value1':'value2'] where <column1>='some value';
示例
cqlsh:keyspace3>UPDATE college student SET EMAIL=EMAIL+['hardikgupta.1@gmail.com'] where EN=001;
输出
EN |
NAME |
|
---|---|---|
001 |
hardik |
hardikgupta.1@gmail.com |
002 |
Ajites |
ajit@mail.com |
003 |
Pushpa |
tears@mail.com |
结论
以上是 Apache Cassandra 中的三种集合数据类型。通过 Cassandra 集合可以轻松进行任务管理。集合允许存储大量项目。