redis 学习札记4-sortset
redis 学习笔记4--sortset
redis学习笔记3--sortSet
终于到最后一个数据结构了,加油!!
整体结构图:
http://dl.iteye.com/upload/picture/pic/115995/0ee3789f-33e1-35ca-ac65-cbd6b4e4e147.jpg
1.ZADD
语法: ZADD key score value
释义:添加执行分数的value, score必须是double类型的数值
实践:
redis 127.0.0.1:6379> zadd z1 1 a
(integer) 1
redis 127.0.0.1:6379> zadd z1 2 b
(integer) 1
redis 127.0.0.1:6379> zadd z1 20 bb
(integer) 1
redis 127.0.0.1:6379> zadd z1 10 ff
(integer) 1
redis 127.0.0.1:6379> zrange z1 0 -1
1) "a"
2) "b"
3) "ff"
4) "bb"
2.ZREM
语法:ZREM key value
释义:删除指定value的值
实践:
redis 127.0.0.1:6379> ZREM z1 b // 删除,指定value
(integer) 1
redis 127.0.0.1:6379> zrange z1 0 -1
1) "a"
2) "ff"
3) "bb"
3.ZCARD
语法:ZCARD key
释义:获取集合总数
实践:
redis 127.0.0.1:6379> zrange z1 0 -1
1) "a"
2) "ff"
3) "bb"
redis 127.0.0.1:6379> zcard z1
(integer) 3
4.ZCOUNT
语法:zcount key min max
释义:计算在指定范围内的元素数目
(1 6 ==== 1 < x <= 6 // 括号代表开区间
1 6 ==== 1 <= x <= 6
实践:
redis 127.0.0.1:6379> zrange z1 0 -1 withscores
1) "a"
2) "1"
3) "ff"
4) "10"
5) "bb"
6) "20"
redis 127.0.0.1:6379> zcount z1 5 10 // 闭区间,能取得10
(integer) 1
redis 127.0.0.1:6379> zcount z1 5 (10 //开区间,无法得到10
(integer) 0
5.ZSCORE
语法:ZSCORE key value
释义:获取指定key的分数
实践:
redis 127.0.0.1:6379> zrange z1 0 -1 withscores
1) "a"
2) "1"
3) "ff"
4) "10"
5) "bb"
6) "20"
redis 127.0.0.1:6379> zscore z1 a // 获取a的分数
"1"
6.ZINCRBY
语法:ZINCRBY key score value
释义:对于指定的value进行加法操作
实践:
redis 127.0.0.1:6379> zrange z1 0 -1 withscores
1) "a"
2) "1"
3) "ff"
4) "10"
5) "bb"
6) "20"
redis 127.0.0.1:6379> zincrby z1 10 a // 对于a+10
"11"
redis 127.0.0.1:6379> zrange z1 0 -1 withscores
1) "ff"
2) "10"
3) "a"
4) "11"
5) "bb"
6) "20"
redis 127.0.0.1:6379> zincrby z1 -3 a // 对于a-3
"8"
redis 127.0.0.1:6379> zrange z1 0 -1 withscores
1) "a"
2) "8"
3) "ff"
4) "10"
5) "bb"
6) "20"
7.ZRANGE|ZREVRANGE
语法:ZRANGE|ZREVRANGE key
释义:显示所有列表
redis 127.0.0.1:6379> zrange z1 0 -1
1) "a"
2) "ff"
3) "bb"
redis 127.0.0.1:6379> zrevrange z1 0 -1
1) "bb"
2) "ff"
3) "a"
8.ZRANGEBYSCORE|ZREVRANGEBYSCORE
语法:ZRANGEBYSCORE key min max [WITHSCORES] [LIMIT offset count]
释义:获取指定范围内的数值
实践:
redis 127.0.0.1:6379> zrange z1 0 -1 withscores
1) "a"
2) "8"
3) "ff"
4) "10"
5) "bb"
6) "20"
redis 127.0.0.1:6379> zrangebyscore z1 -inf +inf // 在不清楚最大最小范围的时间,可以采用这个 -inf +inf
1) "a"
2) "ff"
3) "bb"
redis 127.0.0.1:6379> zrangebyscore z1 8 10 // 闭区间
1) "a"
2) "ff"
redis 127.0.0.1:6379> zrangebyscore z1 (8 10 // 开区间
1) "ff"
9.ZRANK|ZREVRANK
语法:zrank|zremrank key member
释义:获取指定值在集合中的排名,以0代表第一位 。(顺序或是逆序)
redis 127.0.0.1:6379> zrange z1 0 -1 withscores
1) "a"
2) "8"
3) "ff"
4) "10"
5) "bb"
6) "20"
redis 127.0.0.1:6379> zrank z1 a
(integer) 0
redis 127.0.0.1:6379> zrank z1 ff //顺序位置
(integer) 1
redis 127.0.0.1:6379> zrevrank z1 a //逆序位置
(integer) 2
10.ZREMRANGEBYRANK
语法 :ZREMRANGEBYRANK key min max
释义:删除指定下标的数据
实践:
redis 127.0.0.1:6379> zrange z1 0 -1
1) "a"
2) "ff"
3) "bb"
redis 127.0.0.1:6379> zremrangebyrank z1 0 1
(integer) 2
redis 127.0.0.1:6379> zrange z1 0 -1
1) "bb"
11.ZREMRANGEBYSCORE
语法 :ZREMRANGEBYSCORE key min max
释义:根据指定分数删除数据
实践:
redis 127.0.0.1:6379> zrange z1 0 -1 withscores
1) "bb"
2) "20"
redis 127.0.0.1:6379> ZREMRANGEBYSCORE z1 -inf +inf // 删除所有的数据 等同于 del z1
(integer) 1
redis 127.0.0.1:6379> zrange z1 0 -1
(empty list or set)
12.ZINTERSTORE
语法:ZINTERSTORE destination numkeys key [key ...] [WEIGHTS weight [weight ...]] [AGGREGATE SUM|MIN|MAX]
释义:
计算给定的一个或多个有序集的交集,其中给定 key 的数量必须以 numkeys 参数指定,并将该交集(结果集)储存到 destination 。
默认情况下,结果集中某个成员的 score 值是所有给定集下该成员 score 值之和.
实践:
redis 127.0.0.1:6379> zrange s1 0 -1
1) "a"
2) "b"
3) "c"
redis 127.0.0.1:6379> zrange s2 0 -1
1) "a"
2) "c"
3) "d"
redis 127.0.0.1:6379> zinterstore s3 2 s1 s2
(integer) 2
redis 127.0.0.1:6379> zrange s3 0 -1
1) "a"
2) "c"
redis 127.0.0.1:6379>
13.ZUNIONSTORE
语法:ZUNIONSTORE destination numkeys key [key ...] [WEIGHTS weight [weight ...]] [AGGREGATE SUM|MIN|MAX]
释义:计算给定的一个或多个有序集的并集,其中给定 key 的数量必须以 numkeys 参数指定,并将该并集(结果集)储存到 destination 。
默认情况下,结果集中某个成员的 score 值是所有给定集下该成员 score 值之 和 。
WEIGHTS
使用 WEIGHTS 选项,你可以为 每个 给定有序集 分别 指定一个乘法因子(multiplication factor),每个给定有序集的所有成员的 score 值在传递给聚合函数(aggregation function)之前都要先乘以该有序集的因子。
如果没有指定 WEIGHTS 选项,乘法因子默认设置为 1 。
AGGREGATE
使用 AGGREGATE 选项,你可以指定并集的结果集的聚合方式。
默认使用的参数 SUM ,可以将所有集合中某个成员的 score 值之 和 作为结果集中该成员的 score 值;使用参数 MIN ,可以将所有集合中某个成员的 最小 score 值作为结果集中该成员的 score 值;而参数 MAX 则是将所有集合中某个成员的 最大 score 值作为结果集中该成员的 score 值。
实践:
redis 127.0.0.1:6379> zunionstore s3 2 s1 s2
(integer) 4
redis 127.0.0.1:6379> zrange s3 0 -1
1) "b"
2) "a"
3) "c"
4) "d"
redis 127.0.0.1:6379>
redis 学习札记4-sortset的更多相关文章
- Redis学习手册(目录)
为什么自己当初要选择Redis作为数据存储解决方案中的一员呢?现在能想到的原因主要有三.其一,Redis不仅性能高效,而且完全免费.其二,是基于C/C++开发的服务器,这里应该有一定的感情因素吧.最后 ...
- redis 学习笔记(6)-cluster集群搭建
上次写redis的学习笔记还是2014年,一转眼已经快2年过去了,在段时间里,redis最大的变化之一就是cluster功能的正式发布,以前要搞redis集群,得借助一致性hash来自己搞shardi ...
- Redis——学习之路四(初识主从配置)
首先我们配置一台master服务器,两台slave服务器.master服务器配置就是默认配置 端口为6379,添加就一个密码CeshiPassword,然后启动master服务器. 两台slave服务 ...
- Redis——学习之路三(初识redis config配置)
我们先看看config 默认情况下系统是怎么配置的.在命令行中输入 config get *(如图) 默认情况下有61配置信息,每一个命令占两行,第一行为配置名称信息,第二行为配置的具体信息. ...
- Redis——学习之路二(初识redis服务器命令)
上一章我们已经知道了如果启动redis服务器,现在我们来学习一下,以及如何用客户端连接服务器.接下来我们来学习一下查看操作服务器的命令. 服务器命令: 1.info——当前redis服务器信息 s ...
- Redis学习笔记~目录
回到占占推荐博客索引 百度百科 redis是一个key-value存储系统.和Memcached类似,它支持存储的value类型相对更多,包括string(字符串).list(链表).set(集合). ...
- Redis学习笔记4-Redis配置详解
在Redis中直接启动redis-server服务时, 采用的是默认的配置文件.采用redis-server xxx.conf 这样的方式可以按照指定的配置文件来运行Redis服务.按照本Redi ...
- Redis学习笔记1-Redis的介绍和认识
说明:文章内容来自百度百科和redis官方对redis的介绍 Redis是一个开源的使用ANSI C语言编写.支持网络.可基于内存亦可持久化的日志型.Key-Value数据库,并提供多种语言的API ...
- Redis学习笔记7--Redis管道(pipeline)
redis是一个cs模式的tcp server,使用和http类似的请求响应协议.一个client可以通过一个socket连接发起多个请求命令.每个请求命令发出后client通常会阻塞并等待redis ...
随机推荐
- unity 静态合批
想做这样一个优化 因为cmd drawcall太多 materials太多导致 实际上只是贴图不一样 想用texture2DArray把他们合起来 texArray这步功能倒是很快就好了 但是从fra ...
- JAVASCRIPT校验大全[转]
var IsFireFox = document.getElementById &&! document.all;//判断是否为FireFox //页面里回车到下一控件的焦点 func ...
- jquery选择器的实现流程简析及提高性能建议!
当我们洋洋得意的使用jquery强大的选择器功能时有没有在意过jquery的选择性能问题呢,其实要想高效的使用jquery选择器,了解其实现流程是很有必要的,那么这篇文章我就简单的讲讲其实现流程,相信 ...
- python 分词计算文档TF-IDF值并排序
文章来自于我的个人博客:python 分词计算文档TF-IDF值并排序 该程序实现的功能是:首先读取一些文档,然后通过jieba来分词,将分词存入文件,然后通过sklearn计算每一个分词文档中的tf ...
- [置顶] ios 无限循环翻页源码例子
原创文章,转载请注明出处:http://blog.csdn.net/donny_zhang/article/details/9923053 demo功能:ios 无限循环翻页源码例子.iphone 6 ...
- Transform导入数据源TR1008错误
cognos在建设初期开发者们都常常遇到的一个问题,在这里做一下小小的总结. iqd作为Transform的数据源导入数据的时候遭遇TR1008错误 注意: 从报错的内容可以看出transform不能 ...
- matlab中find函数的使用说明
matlab中如何统计一个矩阵M中零的个数 size(find(M==0),1) 原文:http://blog.sina.com.cn/s/blog_707b64550100rbh3.html fin ...
- shapefile文件的符号化问题
我们都知道,ArcGIS的shp文件只以坐标形式保存地图数据,地图的显示方法则是存储都数据库或地图文件(mxd)中,这一点是深信不疑的. 如果我们打开ArcMap,新建一个普通的地图文件(使用标准的模 ...
- youtube相关
Ubuntu环境巧妙下载YouTube视频 http://www.linuxidc.com/Linux/2008-07/14555.htm 今天,我就为大家介绍在Ubuntu环境总一个专门从 YouT ...
- Java从零开始学五(数据类型转换)
一.数据类型转换 分为“自动类型转换”和“强制类型转换” 二.自动类型转换 低级别------>高级别 byte b=7; int i=b; System.out.println("i ...