三、集合列

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. Java_Hbase Timeout issue

    设置参数hbase.rpc.timeout <property><name>hbase.regionserver.lease.period</name><va ...

  2. Discuz!X/模板标签说明

    Discuz 模板标签说明 Discuz! 的模板采用近似 PHP 表达式的语法,基本都是可识别的HTML,但涉及到变量和动态内容时,基本形式下: <!-{ 代码内容 }-> 逻辑元素包围 ...

  3. mysql颠覆实战笔记(二)-- 用户登录(一):唯一索引的妙用

    版权声明:笔记整理者亡命小卒热爱自由,崇尚分享.但是本笔记源自www.jtthink.com(程序员在囧途)沈逸老师的<web级mysql颠覆实战课程 >.如需转载请尊重老师劳动,保留沈逸 ...

  4. java 操作sqllite的数据库

    介绍 sqllite是一个小型数据库,不依赖于数据库服务器,操作它可以像操作本地的文本文件一样.在Android中是用来存储数据到本地的,java中可能也会有用到sqllite需要. 详细 sqlli ...

  5. Umbraco入门(一)--在VS中安装Umbraco

    在VS中安装Umbraco 由于Vs中自己集成的IIS,所以在安装Umbraco是不用再想以前那么麻烦,需要设置IIS等等…… 使用VS的NuGet程序包管理器   创建一个用空的ASP Web应用程 ...

  6. linux安装gcc的一些问题。

    输入命令:yum install gcc 提示: Loaded plugins: fastestmirror, langpacksExisting lock /var/run/yum.pid: ano ...

  7. 【模拟,时针分针秒针两两夹角】【没有跳坑好兴奋】hdu - 5387 (多校#8 1008)

    算是最好写的一道题了吧,最近模拟没手感,一次过也是很鸡冻o(* ̄▽ ̄*)o 注意事项都在代码里,没有跳坑也不清楚坑点在哪~ #include<cstdio> #include<cst ...

  8. Git工作流

    关于git工作原理请参见:http://blog.csdn.net/zdy0_2004/article/details/46552227

  9. 小技巧之a标签自动解析URL

    我们可能都知道javascript中的window.location对象用来获取当前页面的地址URL,并把浏览器重定向到新的页面.它有protocol.hostname.host.port.searc ...

  10. javascript+dom 做javascript图片库

    废话不多说 直接贴代码 <!DOCTYPE html><html lang="en"><head> <meta charset=" ...