ssh admin@192.168.1.1
*******
cqlsh 192.168.1.1
desc keyspaces;
use forseti_fp;
ceate index 索引 on device——session(id);
2015-01-04
查看表空间describe keyspaces;
查看已有表:describe tables;
查看表结构:describe table table_name;
key spaces
describe keyspaces;
describe keyspace {keyspace};
use {keyspace};
select * from system.schema_keyspaces;
Column Families
describe tables;
describe columnfamily {table};
select * from system.schema_columnfamilies;
describe tables table
;
参考:datastax documention : CQL for cassandra 2.x
Cassandra 提供collection 用于处理某些特殊类型的需求,如单用户记录的多个邮件地址,此处翻译为 集合类型。
Cassandra 提供了三种集合类型,分别是Set,List,Map。
基本概念与操作
一、Set
Set存储了一组类型相同的不重复元素,当被查询时会返回排好序的结果,但是内部构成是无序的值,应该是在查询时对结果进行了排序。
使用示例:
1.创建带有Set类型列的表
CREATE TABLE users ( user_id text PRIMARY KEY, first_name text, last_name text, emails set<text> );
2.插入数据
INSERT INTO users (user_id, first_name, last_name, emails) VALUES('frodo', 'Frodo', 'Baggins', {'f@baggins.com', 'baggins@gmail.com'});
3.使用UPDATE命令和‘+’操作符向set列添加一个元素。
UPDATE users SET emails = emails + {'fb@friendsofmordor.org'} WHERE user_id = 'frodo';
4.查询
SELECT user_id, emails FROM users WHERE user_id = 'frodo';
结果如下
user_id | emails ---------+------------------------------------------------------------------- frodo | {"baggins@caramail.com","f@baggins.com","fb@friendsofmordor.org"}
注: Cassandra 会按照set内数据类型进行排序返回 查询结果,如果希望按照插入序返回结果,请使用list.
5.删除一个元素
UPDATE users SET emails = emails - {'fb@friendsofmordor.org'} WHERE user_id = 'frodo';
6.删除所有元素
可以使用UPDATA或DELETE命令
UPDATE users SET emails = {} WHERE user_id = 'frodo'; DELETE emails FROM users WHERE user_id = 'frodo';
一般来说,Set,list和Map要求最少有一个元素,否则Cassandra无法把其同一个空值区分。
二、List
list查询时会按照元素在list中的index顺序来返回结果,可以存储多个重复的值。
操作示例:
1.向users表添加一个list列
ALTER TABLE users ADD top_places list<text>;
2.使用UPDATA命令向list插入值。
UPDATE users SET top_places = [ 'rivendell', 'rohan' ] WHERE user_id = 'frodo';
3.在list前面插入值
UPDATE users SET top_places = [ 'the shire' ] + top_places WHERE user_id = 'frodo';
4.在list后面插入值
UPDATE users SET top_places = top_places + [ 'mordor' ] WHERE user_id = 'frodo';
5.使用列表索引设置特定位置的值
UPDATE users SET top_places[2] = 'riddermark' WHERE user_id = 'frodo';
原先的值会被覆盖,这种操作会读入整个list,效率比3,4低
6.使用DELETE命令和索引删除某个特定位置的值。
DELETE top_places[3] FROM users WHERE user_id = 'frodo';
7.使用UPDATE命令和‘-’移除list中所有的特定值。
UPDATE users SET top_places = top_places - ['riddermark'] WHERE user_id = 'frodo';
6和7相比,推荐使用7,因为6操作是非线程安全的,如果在操作时其它线程在前面添加了一个元素,会导致移除错误的元素。使用7不会有此问题。
三、Map
Map提供了名字到值的映射,Map可以存储时间戳相关的信息,每一个元素在内部作为一列存储,可以修改,替换,删除和查询,拥有一个单独的TTL值。
操作示例:
1.添加Map列
ALTER TABLE users ADD todo map<timestamp, text>;
2.使用Insert或Update命令,设置或更新数据。
UPDATE users SET todo = { '2012-9-24' : 'enter mordor', '2014-10-2 12:00' : 'throw ring into mount doom' } WHERE user_id = 'frodo';
3.使用UPDATE命令设置指定元素的value
UPDATE users SET todo['2014-10-2 12:00'] = 'throw my precious into mount doom' WHERE user_id = 'frodo';
4.使用INSERT命令设置指定行的map数据。
INSERT INTO users (user_id, todo) VALUES ('frodo', { '2013-9-22 12:01' : 'birthday wishes to Bilbo', '2013-10-1 18:00': 'Check into Inn of Pracing Pony'}) ;
旧的MAP数据会被覆盖。
在 Cassandra 2.1.1后,可以使用如下语法增加map元素。如果key已存在,value会被覆盖,不存在则插入。
UPDATE users SET todo = todo + { '2013-9-22 12:01' : 'birthday wishes to Bilbo', '2013-10-1 18:00': 'Check into Inn of Pracing Pony'} WHERE user_id='frodo';
5.删除元素。
DELETE todo['2013-9-22 12:01'] FROM users WHERE user_id = 'frodo';
UPDATE users SET todo=todo - {'2013-9-22 12:01','2013-10-01 18:00:00-0700'} WHERE user_id='frodo';
6.查询元素。
SELECT user_id, todo FROM users WHERE user_id = 'frodo';
map输出顺序取决于map类型。
7.使用TTL
UPDATE users USING TTL <computed_ttl> SET todo['2012-10-1'] = 'find water' WHERE user_id = 'frodo';
INSERT INTO users (user_name, password) VALUES ('cbrown', 'ch@ngem4a') USING TTL 86400;
在设定的computed_ttl数值秒后,数据会自动删除。
使用集合类型要注意:
1.集合的每一项最大是64K。
2.保持集合内的数据不要太大,免得Cassandra 查询延时过长,只因Cassandra 查询时会读出整个集合内的数据,集合在内部不会进行分页,集合的目的是存储小量数据。
3.不要向集合插入大于64K的数据,否则只有查询到前64K数据,其它部分会丢失。
高级应用
一、给集合添加索引
从 Cassandra 2.1起,可以给集合添加索引。
示例:
CREATE INDEX ON users(emails); CREATE INDEX mymapvalues ON users(todo);
索引名字可以不指定。
上面第二个语句使用Map列的列名在其values上创建了索引,也可以在其keys上创建索引,如下:
DROP INDEX mymapvalues; CREATE INDEX mymapkeys ON playlists (KEYS(todo));
二、过滤集合中的数据
假设已经给集合添加了索引,就可以使用where子句的CONTAINS条件按照给定的值进行过滤。
SELECT user_id FROM users WHERE emails CONTAINS 'baggins@gmail.com';
注意给定的值是集合项的一项,短于集合某项不会进行模糊匹配。
对于MAP,可以使用key或value进行过滤。
SELECT user_id FROM users WHERE todo CONTAINS 'birthday wishes to Bilbo';
SELECT user_id FROMusers WHERE todo CONTAINSKEY'2013-09-23 12:01:00-0700';
相关推荐
C2000,28335Matlab Simulink代码生成技术,处理器在环,里面有电力电子常用的GPIO,PWM,ADC,DMA,定时器中断等各种电力电子工程师常用的模块儿,只需要有想法剩下的全部自动代码生成, 电源建模仿真与控制原理 (1)数字电源的功率模块建模 (2)数字电源的环路补偿器建模 (3)数字电源的仿真和分析 (4)如何把数学控制方程变成硬件C代码; (重点你的想法如何实现)这是重点数字电源硬件资源、软件设计、上机实验调试 (1) DSP硬件资源; (2)DSP的CMD文件与数据的Q格式: (3) DSP的C程序设计; (4)数字电源的软件设计流程 (5)数字电源上机实验和调试(代码采用全中文注释)还有这个,下面来看看都有啥,有视频和对应资料(S代码,对应课件详细讲述传递函数推倒过程。
OpenArk64-1.3.8beta版-20250104,beta版解决Windows 11 23H2及以上进入内核模式,查看系统热键一片空白的情况
java面向对象程序设计实验报告
基于springboot的校园台球厅人员与设备管理系统--论文.zip
【创新无忧】基于matlab蜣螂算法DBO优化极限学习机KELM故障诊断【含Matlab源码 10720期】.zip
基于springboot的数码论坛系统设计与实现--论文.zip
基于springboot的生鲜超市管理的设计与实现.zip
内容概要:本文针对污水再生全流程中首端处理单元——AO除磷工艺展开了详尽研究。首先介绍了当前国内水资源现状以及传统污水处理面临的挑战。基于这些挑战,研究人员提出了将A/O除磷与厌氧氨氧化相结合的新思路,并详细讨论了如何通过调控运行参数(如好氧段DO浓度、污泥负荷率等)来提升TP和COD的去除效果。文章强调在不牺牲氨氮浓度的前提下实现了高效低成本的除磷及有机物去除。同时利用DGGE技术探究了系统内的微生物群落结构,验证氨氧化细菌和亚硝化细菌在短泥龄条件下被淘汰的情况。 适合人群:从事污水处理技术研究的专业人士或对生物处理工艺感兴趣的环保工程师、科研人员。 使用场景及目标:①为改善传统污水处理工艺中存在的同步脱氮除磷难题提供解决方案;②探讨A/O除磷单元与其他处理单元组合时的设计考量和性能评估方法。 其他说明:本研究不仅有助于深入了解AO工艺背后的科学原理和技术难点,也为后续自养脱氮环节准备了合适的进水条件,促进了整个城市污水处理链条的技术进步和发展方向探索。
返岗证明模板.docx
arcgis矢量shp格式白城市地图
航天新征程航天发展历程介绍弘扬载人航天精神ppt
Yufeng-lidar
资源描述: HTML5实现好看的律师法律服务网站模板,好看的律师法律服务网站模板源码,律师法律服务网站模板,HTML律师法律服务网站模板源码,内置酷炫的动画,界面干净整洁,页面主题,全方位介绍内容,可以拆分多个想要的页面,可以扩展自己想要的,注释完整,代码规范,各种风格都有,代码上手简单,代码独立,可以直接运行使用。也可直接预览效果。 资源使用: 点击 index.html 直接查看效果
【创新无忧】基于matlab哈里斯鹰算法HHO优化极限学习机KELM故障诊断【含Matlab源码 10697期】.zip
【C#】基于C#的消息队列服务产品中间件
【创新无忧】基于matlab布谷鸟算法CS优化极限学习机KELM故障诊断【含Matlab源码 10691期】.zip
直连设备(单片机)端token自动计算(micropython)
基于springboot的书籍学习平台--论文.zip
档案材料归档移交目录表.docx
这是我自己写的一款PDF文档转Word工具。 没有联网,没有后台,格式转换在本地电脑上进行,保证数据安全。 转换有4种模式可以设置,尽可能的保证转换成功,保留原来的格式。