
我们将在 Cassandra 之旅中查看 Cassandra 集合数据类型教程。在本文中,我们将了解 Cassandra 的 Collection 数据类型。这些数据类型与 C、C++ 等中的数组和结构具有相同的意义。
此外,我们将讨论使用列表、集合和映射的 Cassandra 集合数据类型。
因此,让我们从 Cassandra 集合数据类型开始。
Cassandra 的集合数据类型
在 Cassandra 中,集合数据类型本质上是多个值的存储容器。通常,Cassandra-CQL 集合数据类型由单个变量定义。该变量本身有一个值范围。
列表、集合和映射是几种集合数据类型。对这些 Cassandra 集合数据类型执行大量操作。其中包括创建、插入、更新和验证操作。
a)Cassandra 列表
此数据类型的值以列表形式保存。该列表包含单个值的多个副本。对于列表数据类型,只有一条规则。
元素不能按顺序修改。值存储在列表中后,元素会被赋予特定的索引。这些索引可用于获取值。
i) 创建表
在 Cassandra 中,个人可以使用 CREATE TABLE 命令创建具有列表数据类型的表。表中可能有很多列。创建表的语法是。
cqlsh:>CREATE TABLE
(column1 PRIMARY KEY,column2 list ,column3 list ,.....);
登录后复制
构建一个表,其中包含“大学生”的名称、学号和分支。
cqlsh> USE keyspace1;
cqlsh:keyspace1> CREATE TABLE employee
... (EN int,
... NAME text,
... EMAIL LIST,
... PRIMARY KEY(EN),
... );
登录后复制
输出
ii) 插入
用户可以使用 INSERT INTO 命令将组件添加到表中。方括号中包含的每个值均以逗号分隔。语法是 -
cqlsh:> INSERT INTO
(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'});
登录后复制
输出
|
一个
|
姓名
|
电子邮件
|
|
001
|
哈迪克
|
hardi@gmail.com
|
|
002
|
阿吉特斯
|
ajit@mail.com
|
|
003
|
普什帕
|
tears@mail.com
|
iii) 更新
Cassandra 的 UPDATE 命令用于更新某些表列的值。更新语法如下。
cqlsh: UPDATE
SET =+['value']
where ='some value';
登录后复制
示例
cqlsh:keyspace2>UPDATE college student
SET EMAIL=EMAIL+['hardikgupta.1@gmail.com']
where EN=001;
登录后复制
输出
|
一个
|
姓名
|
电子邮件
|
|
001
|
哈迪克
|
hardikgupta.1@gmail.com
|
|
002
|
阿吉特斯
|
ajit@mail.com
|
|
003
|
普什帕
|
tears@mail.com
|
b) 卡桑德拉集
用户可以使用 SET Cassandra 集合数据类型来存储元素集合。执行完毕后,集合的组成部分会以排序的方式返回。
我。创建表
用户可以使用具有以下语法的构造命令来创建包含该集的表。
cqlsh: CREATE TABLE
(column1 PRIMARY KEY, column2 set , column3 set .....);
登录后复制
示例
构建一个表,其中包含“大学生”的名称、学号和分支。
cqlsh> USE keyspace2;
cqlsh:keyspace2> CREATE TABLE employee
... (EN int,
... NAME text,
... EMAIL LIST,
... PRIMARY KEY(EN),
... );
登录后复制
输出
ii.卡桑德拉插入
INSERT INTO 命令与以下语法一起使用,将值插入到集合中。
cqlsh:> INSERT INTO
(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'});
登录后复制
输出
|
一个
|
姓名
|
电子邮件
|
|
001
|
哈迪克
|
hardi@gmail.com
|
|
002
|
阿吉特斯
|
ajit@mail.com
|
|
003
|
普什帕
|
tears@mail.com
|
iii.卡桑德拉更新
用户可以使用此语法更新集合中的内容。
cqlsh:>UPDATE
SET =+['value']
where ='some value';
登录后复制
示例
cqlsh:keyspace2>UPDATE college student
SET EMAIL=EMAIL+['hardikgupta.1@gmail.com']
where EN=001;
登录后复制
输出
|
一个
|
姓名
|
电子邮件
|
|
001
|
哈迪克
|
hardikgupta.1@gmail.com
|
|
002
|
阿吉特斯
|
ajit@mail.com
|
|
003
|
普什帕
|
tears@mail.com
|
c)Cassandra 地图
一对键值项存储在映射(Cassandra 集合数据类型)中。
我。创建表
用户可以使用以下语法的“构造”命令来创建带有地图的表。
cqlsh: CREATE TABLE
(column1 PRIMARY KEY, column2 map , column3 map .....);
登录后复制
构建一个表,其中包含“大学生”的名称、学号和分支。
cqlsh> USE keyspace3;
cqlsh:keyspace3> CREATE TABLE employee
... (EN int,
... NAME text,
... EMAIL LIST,
... PRIMARY KEY(EN),
... );
登录后复制
输出
ii.插入
INSERT INTO 命令与以下语法一起使用,将值插入到映射中。
cqlsh:> INSERT INTO
(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'});
登录后复制
输出
|
一个
|
姓名
|
电子邮件
|
|
001
|
哈迪克
|
hardi@gmail.com
|
|
002
|
阿吉特斯
|
ajit@mail.com
|
|
003
|
普什帕
|
tears@mail.com
|
iii.更新
使用此技术,用户可以修改集合的内容。
cqlsh:>UPDATE
SET =+['value1':'value2']
where ='some value';
登录后复制
示例
cqlsh:keyspace3>UPDATE college student
SET EMAIL=EMAIL+['hardikgupta.1@gmail.com']
where EN=001;
登录后复制
输出
|
一个
|
姓名
|
电子邮件
|
|
001
|
哈迪克
|
hardikgupta.1@gmail.com
|
|
002
|
阿吉特斯
|
ajit@mail.com
|
|
003
|
普什帕
|
tears@mail.com
|
结论
这是 Apache Cassandra 中的三种集合数据类型。通过 Cassandra 集合可以轻松进行任务管理。集合允许存储大量项目。
以上就是Apache Cassandra 中的集合数据类型的详细内容,更多请关注每日运维网(www.mryunwei.com)其它相关文章!
相关推荐
string:字符串 list:列表 hash:散列表 set:无序集合 zset:有序集合 接下来我们就要针对这五种数据结构,来分析其底层的结构 这里选用的版本是redis-5.0.4,所以可能有很多地方和如今网络上的其他博文不太一致,不同的地方我会在文中指出 string 因为redis使用c语言开发,所以自然没有java和c++的那些字符串类库,在redis中,其自己定义了一种字符串格式,叫
CentOS是一种流行的Linux操作系统。Oracle是业内知名的数据库软件之一。sqlplus是Oracle公司提供的命令行工具,具有丰富的数据库操作功能。CentOS + Oracle + sqlplus的组合可以为用户提供可靠的数据库管理解决方案。下面,本文将详细介绍如何在CentOS上安装、配置和使用Oracle sqlplus。 安装Oracle数据客户端 安装Oracle客户端是sq
mssql数据库中外键应用实践 Microsoft SQL Server (MSSQL) 是最受欢迎的关系型数据库管理系统之一,它功能强大,受到广泛应用于企业级数据库系统中。 MSSQL 的外键功能是它不同于其他关系型数据库管理系统的独特优势。外键可以让你建立在两个表之间的强大关系,以保证数据一致性、完整性以及可维护性。 首先,让我们介绍下 MSSQL 中的外键机制。外键的实质是在两个表之间建立一
MySQL 是一种关系数据库管理系统,它被广泛用于开发各种类型的应用程序。在餐饮行业,点餐系统是非常常见的应用。本文将重点介绍如何使用MySQL实现点餐系统的配送管理功能,并提供具体的代码示例。 一、数据库设计在设计数据库之前,首先需要明确系统的需求和功能。点餐系统的配送管理功能包括以下几个方面: 配送员管理:记录配送员的基本信息,包括姓名、手机号码等。 订单管理:记录订单的基本信息,包括订单编号
MySQL是一种广泛使用的关系数据库管理系统。它是一个开放源代码的软件,是LAMP软件组合中的一个重要组成部分。MySQL是最流行的关系数据库管理系统之一,它有许多先进的功能,如版本控制。 MySQL版本控制是MySQL特有的功能,它允许开发人员跟踪和管理数据库中数据的更改历史。这意味着MySQL可以记录对数据库表格的任何种类的更改,包括添加、修改或删除数据。版本控制可以通过使用时间序列跟踪数据库
回到顶部