7

我已经开始使用 Cassandra 数据库。我打算使用Datastax API来更新/读取 cassandra 数据库。我对这个 Datastax API(它使用新的二进制协议)完全陌生,我也找不到很多文档,其中有一些适当的例子。

当我使用 Netflix 客户端(Astyanax 客户端)使用 Cassandra CLI 时,我创建了这样的列族 -

create column family profile
with key_validation_class = 'UTF8Type'
and comparator = 'UTF8Type'
and default_validation_class = 'UTF8Type'
and column_metadata = [
  {column_name : crd, validation_class : 'DateType'}
  {column_name : lmd, validation_class : 'DateType'}
  {column_name : account, validation_class : 'UTF8Type'}
  {column_name : advertising, validation_class : 'UTF8Type'}
  {column_name : behavior, validation_class : 'UTF8Type'}
  {column_name : info, validation_class : 'UTF8Type'}
  ];

现在我尝试使用 Datastax API 做同样的事情。因此,要开始使用 Datastax API,我是否需要以上述不同的方式创建列族?或者,每当我尝试使用 Datastax API 将数据插入 Cassandra 数据库时,上面的列系列都可以正常工作。

如果上述列族不起作用,那么-

首先,我创建了如下所示的 KEYSPACE -

CREATE KEYSPACE USERS WITH strategy_class = 'SimpleStrategy' AND strategy_options:replication_factor = '1';

现在我很困惑如何创建表?我不确定哪种方法是正确的?

我应该这样创作吗?

CREATE TABLE profile ( id varchar, account varchar, advertising varchar, behavior varchar, info varchar, PRIMARY KEY (id) );

还是我应该这样创作?

CREATE COLUMN FAMILY profile ( id varchar, account varchar, advertising varchar, behavior varchar, info varchar, PRIMARY KEY (id) );

以及如何添加-

crd as DateType
lmd as DateType

在使用 Datastax API 时在上面的表或列族中?

任何帮助将不胜感激。

4

5 回答 5

14

无论您使用关键字TABLE还是COLUMNFAMILY,两者都是相同的(同义词)。我猜想关键字TABLE是在 CQL3 中引入的。所以你可以在你的陈述中使用任何一个。

第二个问题,添加DateType,你应该使用时间戳。

CREATE COLUMNFAMILY sample (rowkey text, ts timestamp, PRIMARY KEY(rowkey));

INSERT INTO sample (rowkey, ts ) VALUES ( '1','1366354711797');
// ts value is basically the System.currentTimeMillis(), I mean a long value
于 2013-04-19T07:03:48.517 回答
1

在 cassandra 中,键空间或数据库是相同的,就像明智的列族和表一样。

Cassandra在语法上更像Mysql,并且支持hql(类似于sql)

cassandra 中的表可以这样创建:

CREATE TABLE users (
user_name varchar,
password varchar,
gender varchar,
session_token varchar,
state varchar,
birth_year bigint,
PRIMARY KEY (user_name));

更多信息:Cassandra 教程

于 2015-08-11T16:11:35.527 回答
1

@neel4soft - 有了 Cassandra,事情就简单地发展了。因此,为了让人们更轻松,正在稳步进行重命名过程,以使从 SQL 到 CQL 的过渡对新手来说更容易。然而,CQL 不应该被认为是 SQL 的亲戚,而应该被认为是它母亲身边的第三个堂兄,换句话说,不是近亲。因此,将其与 MySQL 进行比较是对其功能的不恰当印象。

于 2015-08-12T07:46:51.950 回答
0

使用 cassandra-cli 和 cqlsh 创建表/列族时几乎没有区别。

其中之一是,如果我们使用 cassandra-cli 创建表,它将创建紧凑的存储格式,无法进一步更改。

在 cqlsh 中,它不会以这种格式创建,除非我们在创建表/列族时特别提及。

于 2019-04-26T09:50:04.153 回答
0

列族是有序列的集合,它是行的容器,它存储在 Cassandra 键空间中,我们可以在键空间中创建多个列族。

列族也称为 RDBMS 表,但列族不等于表。

每个列族都存储在磁盘上的单独文件中。每行都有一个唯一的键,称为行键。Cassandra 还具有超级列族的概念,它允许通过保存一组不同的列来进行嵌套访问。

在 Column Family 中,我们可以设置数据的默认排序,我们可以制作压缩表,我们可以使用紧凑存储,我们可以设置数据的过期时间。

于 2021-02-15T09:53:58.497 回答