三、集合列

CQL 3 引入了一下集合类型:

set

list

map

  在关系型数据库中,允许用户拥有多个email地址,你可以创建一个email_addresses表与users表存在一个多对一关系。CQL 3能够处理经典的多个电子邮件地址的使用情况,其他使用的情况下可以通过定义的列达到集合的效果。利用集合来解决多个邮件地址的问题是方便和直观的。

  集合类型的另一个用途被证明可以使用音乐服务作为例子。

四、往表中增加一个集合

  上面说的音乐服务的例子包括给歌曲标记标签。从一个关系的角度看,你可以认为把存储行引擎视为分区,包含了聚集的行。为了给歌曲打标签,使用集合类型set。定义集合通过CREATE TABLE或者ALTER TABLE语句。因为songs表已经存在在刚才的例子中了,仅仅修改表是的添加一个集合set——tags:

ALTER TABLE songs ADD tags set<text>;

五、更新一个集合

更新songs 表插入tags 数据:

UPDATE songs SET tags = tags + {'2007'}

WHERE id = 8a172618-b121-4136-bb10-f665cfc469eb;

UPDATE songs SET tags = tags + {'covers'}

WHERE id = 8a172618-b121-4136-bb10-f665cfc469eb;

UPDATE songs SET tags = tags + {'1973'}

WHERE id = a3e64f8f-bd44-4f28-b8d9-6938726e34d4;

UPDATE songs SET tags = tags + {'blues'}

WHERE id = a3e64f8f-bd44-4f28-b8d9-6938726e34d4;

UPDATE songs SET tags = tags + {'rock'}

WHERE id = 7db1a490-5878-11e2-bcfd-0800200c9a66;

一个音乐评论列表和演出时间表(mao集合)可以添加到表:

ALTER TABLE songs ADD reviews list<text>;

ALTER TABLE songs ADD venue map<timestamp, text>;

map的每一个元素,list或者map内部存储为Cassandra的一列。为了更新一个集合,使用UPDATE命令和加 (+) 操作符去增加一个元素和减 (-) 操作符去移除一个元素。例如,更新一个集合:

UPDATE songs

SET tags = tags + {'rock'}

WHERE id = 7db1a490-5878-11e2-bcfd-0800200c9a66;

更新一个列表,使用方括号代替花括号,其他语法相似。

UPDATE songs

SET reviews = reviews + [ 'hot dance music' ]

WHERE id = 7db1a490-5878-11e2-bcfd-0800200c9a66;

更新一个map,使用INSERT :

INSERT INTO songs (id, venue)

VALUES (7db1a490-5878-11e2-bcfd-0800200c9a66,

{ '2013-9-22 12:01'  : 'The Fillmore',

'2013-10-1 18:00' : 'The Apple Barrel'});

插入数据到map中会替换整个map。

六、查询一个集合

  去查询一个集合,在select表达式中包含集合列的名字。

SELECT id, tags FROM songs;

SELECT id, venue FROM songs;

七、什么时候使用集合

  当你想存储或者反规范化一小段数据的时候可以使用集合。集合中项目的值应当小于64K。其他的限制也适用。当存储类似于用户的电话号码、email的标签这些数据的时候集合工作的非常好。如果你需要存储的数据具有无限增长的潜力,如用户发送的信息和传感器接受的事件,请不要不使用集合。相反地,使用一个具有复合主键的表,存储数据在聚类列中。

八、到期的列

  列中的数据可以有一个可选的叫做TTL(生存时间)的截止日期。每当一个列数据被插入时,客户端可以为列中的数据指定一个可选的TTL值,定义的单位为秒。当请求的时间的已经过期,TTL的列标记视为删除的数据(通过一个墓碑)。当列被一个墓碑标记,它们会自动删除在正常的压紧(通过gc_grace_seconds定义) 和修复过程。

  可以使用CQL去设置列的TTL。

  如果你想改变的列一个到期的TTL,你必须重新插入包含一个新的TTL的列。Cassandra中,列的插入是一个插入或更新操作,这取决于是否以前版本的列的存在。这意味着要更新一个未知值的列的TTL,你必须阅读该列,然后重新插入它(带有新的TTL值)。

  TTL列有一个精确的秒,在服务器上的计算。因此,一个非常小的TTL可能没有什么意义。此外,在服务器上的时钟应当是同步的;否则会出现进度减少的现象,因为截止时间在在最初接收到插入的私人的主机上计算,但是在集群中其他节点发现。

  一个过期的列相比于正常的列来说在内存和硬盘会有8字节的额外开销(记录TTL过期时间)。

九、反列

  一个反列是一个特殊的列存储了一个数字,这个数字是用来计数一个特定的事件或过程。例如,你可能使用一个反列去计算一张页面被访问的次数,

  反列必须使用 Counter数据类型。反列只能存储在专用的表中。

  当一个反列被定义以后,客户端程序更新反列通过增加(减少)操作。客户端通过传递名字和增加(减少)的值更新数据,无需时间戳。

  在内部,反列的结构有一点复杂。Cassandra跟踪计数器分布状态通过一个服务器给定时间戳。因为这个原因,集群中所有的节点始终同步使用同一个源(比如NTP——网络时间协议)是重要的。

  不像正常的列,一个对计数器的写入需要在后台的读取去保证副本之间值是一致的。典型的,对于计数器你可以使用一致性级别ONE,因为在一个写入的操作中,隐式读不会影响写入延迟。

十、利用自然键或替代的主键

  对于表的一个考虑是是否使用代理或自然的主键。一个代理键是一个自动生成的键(如UUID)用来唯一标识一行,但是没有与行中具体的数据相关。

  对于某些表来说,可能会包含生成的独一无二的的并且不会在行创建之后再更新的数据。例如,用户表中用户的名字。这叫做一个自然键。自然键是数据更可读并且移除了附加索引或反规范化的需要。然而,除非你的客户端程序确保唯一性,它可能会覆盖数据列。

Cassandra1.2文档学习(18)—— CQL数据模型(下)的更多相关文章

  1. Cassandra1.2文档学习解读计划——为自己鼓劲

    最近想深入研究一下Cassandra,而Cassandra没有中文文档,仅有的一些参考书都是0.7/0.6版本的.因此有个计划,一边学习文档(地址:http://www.datastax.com/do ...

  2. Cassandra1.2文档学习(17)—— CQL数据模型(上)

    参考文档:http://www.datastax.com/documentation/cql/3.0/webhelp/index.html#cql/ddl/ddl_anatomy_table_c.ht ...

  3. Cassandra1.2文档学习(19)—— CQL索引

    参考文档:http://www.datastax.com/documentation/cql/3.0/webhelp/index.html#cql/ddl/ddl_primary_index_c.ht ...

  4. Cassandra1.2文档学习(15)—— 配置数据一致性

    参考文档:http://www.datastax.com/documentation/cassandra/1.2/webhelp/index.html#cassandra/dml/dml_config ...

  5. Cassandra1.2文档学习(1)——Cassandra基本说明

    参考文档:http://www.datastax.com/documentation/cassandra/1.2/webhelp/index.html#cassandra/architecture/a ...

  6. Cassandra1.2文档学习(16)—— 模式的变化

    参考文档:http://www.datastax.com/documentation/cassandra/1.2/webhelp/index.html#cassandra/dml/dml_schema ...

  7. Cassandra1.2文档学习(13)—— 数据读取

    参考文档:http://www.datastax.com/documentation/cassandra/1.2/webhelp/index.html#cassandra/dml/dml_about_ ...

  8. Cassandra1.2文档学习(4)——分区器

    参考文档:http://www.datastax.com/documentation/cassandra/1.2/webhelp/index.html#cassandra/architecture/a ...

  9. Cassandra1.2文档学习(14)—— 事务和并发控制

    参考文档:http://www.datastax.com/documentation/cassandra/1.2/webhelp/index.html#cassandra/dml/dml_about_ ...

随机推荐

  1. Linux 引导过程内幕

    转载:http://www.ibm.com/developerworks/cn/linux/l-linuxboot/index.html   从主引导记录到第一个用户空间应用程序的指导 引导 Linu ...

  2. vim中光标的前进和后退

    流行的文本编辑器通常都有前进和后退功能,可以在文件中曾经浏览过的位置之间来回移动.在 vim 中使用 Ctrl-O 执行后退,使用 Ctrl-I 执行前进.相关帮助: :help CTRL-O  :h ...

  3. proxy代理类

    package cn.hncu.proxy.rent; import java.lang.reflect.InvocationHandler;import java.lang.reflect.Meth ...

  4. 实用JS大全

    ****************************************************************(一)常用元素,对象,事件,技巧 事件源对象 event.srcElem ...

  5. [Java] HashMap、TreeMap、Hashtable排序

    Java中对Map(HashMap,TreeMap,Hashtable等)的排序时间 首先简单说一下他们之间的区别: HashMap: 最常用的Map,它根据键的HashCode 值存储数据,根据键可 ...

  6. [改善Java代码]适当设置阻塞队列长度

    阻塞队列BlockingQueue扩展了Queue,Collection接口,对元素的插入和提取使用了"阻塞"处理,我们知道Collection下的实现类一般都采用了长度自行管理方 ...

  7. [改善Java代码] 谨慎包装类型的大小比较

    建议27:谨慎包装类型的大小比较 基本数据类型比较大小木有问题,不过其对应的包装类型大小比较就需要注意了.看如下代码: public class Client { public static void ...

  8. JavaScript 三种绑定事件方式之间的区别

    JavaScript三种绑定事件的方式: 1. <div id="btn" onclick="clickone()"></div> // ...

  9. 【Knockout】四、绑定上下文

    Binding context binding context是一个保存数据的对象,你可以在你的绑定中引用它.当应用绑定的时候,knockout自动创建和管理binding context的继承关系. ...

  10. webBrowser1_DocumentCompleted不停被调用

    原文地址:http://blog.csdn.net/shuishenlong/article/details/7950576 关于DocumentCompleted事件,MSDN给出的解释是在文档加载 ...