Cassandra学习五 使用Key的正确姿势

NoSQL一般是反范式的,比如提倡数据冗余,使得不至于写出非常复杂的SQL语句。

Cassandra之中一共包含下面5中Key:

  • Primary Key: 用来获取某一行的数据,可以是一列或多列

                PRIMARY KEY(key_part_one, key_part_two)

     key_part_one -  partition key

          key_part_two - clustering key

PRIMARY KEY((k_part_one,k_part_two), k_clust_one, k_clust_two, k_clust_three)

        复合的partition key, 复合的clustering key

  • Partition Key: (用来进行分区的)Cassandra会对partition key做一个hash计算,并自己决定将记录放到哪个NODE。  partition key 可以是单一主键,也可以是复合主键。但是主键不能重复。

 Cassandra会给每一行数据一个timestamp,如果有多行数据,Cassandra会取时间最新的数据返回

  • Composite Key:
  • Compound Key:
  • Clustering Key:   主要用于进行Range Query(范围查找). 并且使用的时候需要按照建表顺序进行提供信息。
-- 创建表
-- 注意state 这个field
CREATE TABLE users (
  mainland text,
  state text,
  uid int,
  name text,
  zip int,
  PRIMARY KEY ((mainland), state, uid)
) 

-- 插入一些值
insert into users (mainland, state, uid, name, zip) VALUES ( ‘northamerica‘, ‘washington‘, 1, ‘john‘, 98100);
insert into users (mainland, state, uid, name, zip) VALUES ( ‘northamerica‘, ‘texas‘, 2, ‘lukas‘, 75000);
insert into users (mainland, state, uid, name, zip) VALUES ( ‘northamerica‘, ‘delaware‘, 3, ‘henry‘, 19904);
insert into users (mainland, state, uid, name, zip) VALUES ( ‘northamerica‘, ‘delaware‘, 4, ‘dawson‘, 19910);
insert into users (mainland, state, uid, name, zip) VALUES ( ‘centraleurope‘, ‘italy‘, 5, ‘fabio‘, 20150);
insert into users (mainland, state, uid, name, zip) VALUES ( ‘southamerica‘, ‘argentina‘, 6, ‘alex‘, 10840);

有效的查询:

  select * from users where mainland = ‘northamerica‘ and state > ‘ca‘ and state < ‘ny‘;

(mainland), state, uid 构成联合主键,其中mainland是partition key,是hash实现的,所以用=;而state 和UID是clustering key, 是sortedMap实现的可以用于做范                围查找。 原理参考:

1

Map<RowKey, SortedMap<ColumnKey, ColumnValue>>

无效的查询:

-- 没有提供stat 信息
select * from users where mainland = ‘northamerica‘ and uid < 5;

Cassandra 整体数据可以理解成一个巨大的嵌套的Map。 只能按顺序一层一层的深入,不能跳过中间某一层~

create table stackoverflow (
key_part_one text,
key_part_two int,
data text,
PRIMARY KEY(key_part_one, key_part_two)
);

select * from stackoverflow where key_part_one = ‘ronaldo’;         // 这个正确,没有问题

select * from stackoverflow where key_part_two = 9 ALLOW FILTERING  // 一定要有allow filterring
PRIMARY KEY((col1, col2), col3, col4))
正确的where查询条件: 
  • col1 and col2
  • col1 and col2 and col3
  • col1 and col2 and col3 and col4
无效的where查询条件:
col1 (这样Cassandra无法找到在哪一行)
col1 and col2 and col4
anything that does not contain both col1 and col2

总结:

  Cassandra之中的存储,是2-level nested Map(2级嵌套map)

  Partition Key –> Custering Key –> Data 

  partition key: 可以在where中使用  eq and in

  clustering key: 可以在where中使用 < <= = >= > in

原文地址:https://www.cnblogs.com/liufei1983/p/9484551.html

时间: 2024-10-11 03:08:51

Cassandra学习五 使用Key的正确姿势的相关文章

观看学习视频的正确姿势与姿态

开学至今,时时被二柱子逼得走投无路. 痛定思过,目前的自己确实是"三拍",一拍觉得这样那样一定可以胸有成竹,二拍有了点子拿起手术刀就开始实践,三拍无法实现代码拍屁股放弃.啊,我为了二柱子建了好多好多包,想过好多好多条"去北京的路",结果...还是死于基础太烂.也不愿意头悬梁锥刺股.所以呢,那就改进学习方式呗,提高效率. 整个开发过程中,自己犯了一个很大的错误.即是在第五周中途才突然发现,其实代码在整个学习过程中虽说是基础但不是没有它就建不成大楼.而我,白白的把4周的

springMVC3学习(五)--MultiActionController

Spring提供一个多动作控制器,使用它你可以将几个动作合并在一个控制器里,这样可以把功能组合在一起. 多动作控制器存在在一个单独的包中--org.springframework.web.mvc.multiaction--它能够将请求映射到方法名, 然后调用正确的方法.比如当你在一个控制器中有很多公共的功能,但是想多个入口到控制器使用不同的行为, 使用多动作控制器就特别方便. MultiActionController类实现 类定义:public class MultiActionControl

使用 win10 的正确姿势 (第二版)

文章为本人原创,转载请注明出处,谢谢. 17年9月初,写了第一篇<使用 win10 的正确姿势>,而现在半年多过去,文章更新了一些,主要是桌面的变化. 一. 重新定义桌面 我的桌面: 将桌面定义为:临时文件夹.在桌面放置最近需要的文件,使用完毕后归类即可. 任务栏置于左侧:放置一些常用软件,文件,网页等等. 打开其他软件或文件:使用 Listary 这款软件,下文介绍. 小技巧:任务栏有一个搜索栏(win+Q 打开),是查找系统文件的神器.比如 IE.环境变量.程序和功能.截图工具.便利贴等等

转录组分析的正确姿势

转录组分析的正确姿势 转录组分析是目前应用最广的高通量测序分析技术之一.常见设计是不同样品之间比较,寻找差异基因.标志基因.协同变化基因.差异剪接和新转录本,并进行结果可视化.功能注释和网络分析等. 转录组的测序分析也相对成熟,从RNA提取.构建文库.上机测序再到结果解析既可以自己完成,又可以在专业公司进行. 概括来看转录组的分析流程比较简单,序列比对-转录本拼接 (可选)-表达定量-差异基因-功能富集-定制分析.整个环节清晰流畅,可以作为最开始接触高通量测序学习最合适的技术之一. 但重点和难点

揭秘“撩”大数据的正确姿势:生动示例解说大数据“三驾马车”

我是我:"缘起于美丽,相识于邂逅,厮守到白头!" 众听众:"呃,难道今天是要分享如何作诗?!" 我是我:"大家不要误会,今天主要的分享不是如何作诗,而是<揭秘:'撩'大数据的正确姿势>,下面进入正题." 话说当下技术圈的朋友,一起聚个会聊个天,如果不会点大数据的知识,感觉都融入不了圈子,为了以后聚会时让你有聊有料,接下来就跟随我的讲述,一起与大数据混个脸熟吧,不过在"撩"大数据之前,还是先揭秘一下研发这些年我们都经

Node.js中使用redis数据库的正确姿势

Redis是一个常用的Nosql数据库,一般用来代替Memcached做缓存服务,同时它也支持数据的持久化,有着比较广泛的应用场景.在Java中使用redis我们已经比较熟悉了,那么在node.js和koa.js框架中使用Redis的正确姿势是怎样的呢? Redis 是完全开源免费的,遵守BSD协议,是一个高性能的key-value数据库. Redis 与其他 key - value 缓存产品有以下三个特点: * Redis支持数据的持久化,可以将内存中的数据保持在磁盘中,重启的时候可以再次加载

使用layoutinflater的正确姿势

使用layoutinflater的正确姿势 一开始接触安卓开发的时候,知道layoutinflater是用来将布局文件生成对应的View.那时候还是懵懵懂懂知道需要传递一个layoutId一个parent参数和一个false参数.那时候就这样用,初初还是好好的.直到后来随着进一步学习安卓开发发现layoutinflater的这两个参数是有大大的门道在里面. 然后这一篇博客可以说是我对layoutinflater使用的一个总结. 怎么添加一个View到ViewGroup? 在讨论怎么使用layou

qt学习 (五) 登陆界面之连接按钮

登陆步骤是比对输入的账号密码与数据库中的表项目是否一致 一样,  跳出mainwidget对话框 不一样,跳出消息错误框 今天就是要进去, 因为进去以后是widget的窗口,所以把用来核对消息的数据库放在MAINwidget.cpp中, 再拿一个用户点击连接的子类 login.cpp, 就在这里面画用户登录账号密码textEdit 1 除了textEdit 基本都是button 慢慢加. 登录界面可以学的东西很多. 2 在widget.h文件中加入数据库所需要的头文件, #include <Qt

新手第一次使用burpsuite正确姿势

最近我们课程,有个老师需要我帮忙搭建做一个越权攻击的实验.就随手倒腾起burpsuite:最近时间逐渐也比较多了,发现web安全工程师基础入门课程,讲师在第七课对于burpsuite的细节并没有掌握的很好,在浏览器代理操作过程,一直卡在无法顺利抓捕数据包,有点尴尬. 同时我也好久好久不做安全有关的事情,忙于客服.图片设计.美工ui.编辑.销售.运营.项目管理.项目开发层面上,对于课程审查就快速跳过查审,时间实在不够用,没有第一时间给讲师反馈建议很抱歉,对不起. 工具安装与破教程 基于第一次bur