redis的有序集合ZSET(stored set)
相关命令
1.ZADD
ZADD key-name score member [score member……]
将带有给定分值的成员添加到有序集合里
2.ZREM
ZREM key-name member [ member……]
从有序集合中删除指定的成员
php示例
$redis = new redis();
$redis->connect('127.0.0.1', 6609);
$redis->delete('sc1');
$redis->delete('sc2');
$redis -> zAdd('sc1',1,'k1',2,'k2',3,'k3',4,'k4',5,'k5');
$redis -> zAdd('sc1',6,'k6');
$redis -> zAdd('sc1',7,'k7');
var_dump($redis->zRange('sc1', 0, -1));
echo "<br/>";
//结果 array(7) { [0]=> string(2) "k1" [1]=> string(2) "k2" [2]=> string(2) "k3" [3]=> string(2) "k4" [4]=> string(2) "k5" [5]=> string(2) "k6" [6]=> string(2) "k7" }
//rem
var_dump($redis -> zRem('sc1','k2','k3'));
echo "<br/>";
//结果 int(2)
var_dump($redis -> zDelete('sc1','k4','k6'));
//结果 int(2)
echo "<br/>";
var_dump($redis->zRange('sc1', 0, -1));
//结果array(3) { [0]=> string(2) "k1" [1]=> string(2) "k5" [2]=> string(2) "k7" }
zrange参数withscores: bool = false,当为true时
$redis = new redis();
$redis->connect('127.0.0.1', 6609);
$redis->delete('sc1');
$redis->delete('sc2');
$redis -> zAdd('sc1',1,'k1',2,'k2',3,'k3',4,'k4',5,'k5');
$redis -> zAdd('sc1',6,'k6');
$redis -> zAdd('sc1',7,'k7');
var_dump($redis->zRange('sc1', 0, -1,true));
echo "<br/>";
//结果 array(7) { ["k1"]=> float(1) ["k2"]=> float(2) ["k3"]=> float(3) ["k4"]=> float(4) ["k5"]=> float(5) ["k6"]=> float(6) ["k7"]=> float(7) }
//rem
var_dump($redis -> zRem('sc1','k2','k3'));
echo "<br/>";
//结果 int(2)
var_dump($redis -> zDelete('sc1','k4','k6'));
//结果 int(2)
echo "<br/>";
var_dump($redis->zRange('sc1', 0, -1,true));
//结果array(3) { ["k1"]=> float(1) ["k5"]=> float(5) ["k7"]=> float(7) }
3.ZCARD
ZCARD key-name
返回存储在key对应的有序集合中的元素的个数
php示例
$redis->delete('sc1');
$redis -> zAdd('sc1',1,'k1',2,'k2',3,'k3',8,'k8');
var_dump($redis->zRange('sc1', 0, -1,true));
echo "<br/>";
//结果 array(4) { ["k1"]=> float(1) ["k2"]=> float(2) ["k3"]=> float(3) ["k8"]=> float(8) }
var_dump($redis->zSize('sc1'));
echo "<br/>";
//结果 int(4)
var_dump($redis->zCard('sc1'));
echo "<br/>";
//结果 int(4)
4.ZCOUNT
ZCOUNT key-name min max
返回key对应的有序集合中介于min和max间的元素的个数
php示例
var_dump($redis->zRange('sc1', 0, -1));
echo "<br/>";
//结果 array(7) { [0]=> string(2) "k1" [1]=> string(2) "k2" [2]=> string(2) "k3" [3]=> string(2) "k4" [4]=> string(2) "k5" [5]=> string(2) "k6" [6]=> string(2) "k7" }
var_dump($redis->zCount('sc1',2,5));
//结果int(4)
5.ZSCORE
ZSCORE key-name member
返回key对应的有序集合中member的score值。如果member在有序集合中不存在,那么将会返回nil
php示例
var_dump($redis->zRange('sc1', 0, -1,true));
echo "<br/>";
//结果 array(7) { ["k1"]=> float(1) ["k2"]=> float(2) ["k3"]=> float(3) ["k4"]=> float(4) ["k5"]=> float(5) ["k6"]=> float(6) ["k7"]=> float(7) }
var_dump($redis->zScore('sc1','k5'));
//结果float(5)
6.ZINCRBY
ZINCRBY key-name increment member
将key对应的有序集合中member元素的scroe加上increment。
如果指定的member不存在,那么将会添加该元素,并且其score的初始值为increment。
如果key不存在,那么将会创建一个新的有序列表,其中包含member这一唯一的元素。
如果key对应的值不是有序列表,那么将会发生错误
php示例
var_dump($redis->zRange('sc1', 0, -1,true));
echo "<br/>";
//结果 array(7) { ["k1"]=> float(1) ["k2"]=> float(2) ["k3"]=> float(3) ["k4"]=> float(4) ["k5"]=> float(5) ["k6"]=> float(6) ["k7"]=> float(7) }
var_dump($redis->zIncrBy('sc1',8,'k5'));
//结果float(13)
7.ZRANGE
ZRANGE key-name start stop [WITHSCORES]
取得特定范围内的排序元素,0代表第一个元素,1代表第二个以此类推。-1代表最后一个,-2代表倒数第二个
WITHSCORES ,将成员的分值也一并返回
元素按照score从低到高的顺序排列
8.ZREVRANGE
ZREVRANGE key-name start stop [WITHSCORES]
返回key对应的有序集合中指定区间的所有元素。
这些元素按照score从高到低的顺序进行排列。
对于具有相同的score的元素而言,将会按照递减的字典顺序进行排列
php示例
var_dump($redis->zRange('sc1', 0, -1,true));
echo "<br/>";
//结果 array(7) { ["k1"]=> float(1) ["k2"]=> float(2) ["k3"]=> float(3) ["k4"]=> float(4) ["k5"]=> float(5) ["k6"]=> float(6) ["k7"]=> float(7) }
var_dump($redis->zRevRange('sc1',0,-1,true));
//结果array(7) { ["k7"]=> float(7) ["k6"]=> float(6) ["k5"]=> float(5) ["k4"]=> float(4) ["k3"]=> float(3) ["k2"]=> float(2) ["k1"]=> float(1) }
9.ZRANGEBYSCORE
ZRANGEBYSCORE key-name min max [WITHSCORES]
返回key对应的有序集合中score介于min和max之间的所有元素(包哈score等于min或者max的元素)。
元素按照score从低到高的顺序排列
php示例
var_dump($redis->zRange('sc1', 0, -1,true));
echo "<br/>";
//结果 array(7) { ["k1"]=> float(1) ["k2"]=> float(2) ["k3"]=> float(3) ["k4"]=> float(4) ["k5"]=> float(5) ["k6"]=> float(6) ["k7"]=> float(7) }
var_dump($redis->zRangeByScore('sc1', 0, 3));
echo "<br/>";
//结果array(3) { [0]=> string(2) "k1" [1]=> string(2) "k2" [2]=> string(2) "k3" }
var_dump($redis->zRangeByScore('sc1', 0, 3,array('withscores' => TRUE)));
echo "<br/>";
//结果array(3) { ["k1"]=> float(1) ["k2"]=> float(2) ["k3"]=> float(3) }
var_dump($redis->zRangeByScore('sc1', 0, 3,array('limit' => array(1, 1))));
echo "<br/>";
//结果array(1) { [0]=> string(2) "k2" }
var_dump($redis->zRangeByScore('sc1', 0, 3,array('withscores' => TRUE, 'limit' => array(1, 1))));
echo "<br/>";
//结果array(1) { ["k2"]=> float(2) }
10.ZREVRANGEBYSCORE
ZREVRANGEBYSCORE key-name max min [WITHSCORES]
返回key对应的有序集合中score介于min和max之间的所有元素(包哈score等于min或者max的元素)。
元素按照score从高到低的顺序排列
php示例
var_dump($redis->zRange('sc1', 0, -1,true));
echo "<br/>";
//结果 array(7) { ["k1"]=> float(1) ["k2"]=> float(2) ["k3"]=> float(3) ["k4"]=> float(4) ["k5"]=> float(5) ["k6"]=> float(6) ["k7"]=> float(7) }
var_dump($redis->zRevRangeByScore('sc1', 5, 3));
echo "<br/>";
//结果array(3) { [0]=> string(2) "k5" [1]=> string(2) "k4" [2]=> string(2) "k3" }
var_dump($redis->zRevRangeByScore('sc1', 5, 3,array('withscores' => TRUE)));
echo "<br/>";
//结果array(3) array(3) { ["k5"]=> float(5) ["k4"]=> float(4) ["k3"]=> float(3) }
var_dump($redis->zRevRangeByScore('sc1', 5, 3,array('limit' => array(1, 1))));
echo "<br/>";
//结果array(1) { [0]=> string(2) "k4" }
var_dump($redis->zRevRangeByScore('sc1', 5, 3,array('withscores' => TRUE, 'limit' => array(1, 1))));
echo "<br/>";
//结果array(1) { ["k4"]=> float(4) }
11.ZRANK
ZRANK key-name member
返回成员member在有序集合的排名
成员按分值从小到大排列
rank值(或index)是从0开始的
12.ZREVRANK
ZREVRANK key-name member
返回成员member在有序集合的排名
成员按分值从大到小排列
php示例
var_dump($redis->zRange('sc1', 0, -1,true));
echo "<br/>";
//结果 array(7) { ["k1"]=> float(1) ["k2"]=> float(2) ["k3"]=> float(3) ["k4"]=> float(4) ["k5"]=> float(5) ["k6"]=> float(6) ["k7"]=> float(7) }
var_dump($redis->zRank('sc1', 'k2'));
echo "<br/>";
//结果int(1)
var_dump($redis->zRevRank('sc1','k2'));
echo "<br/>";
//结果 int(5)
13.ZREMRANGEBYRANK
ZREMRANGEBYRANK key-name start stop
移除有序集合中排名介于start和stop之间的所有成员
var_dump($redis->zRange('sc1', 0, -1,true));
echo "<br/>";
//结果 array(7) { ["k1"]=> float(1) ["k2"]=> float(2) ["k3"]=> float(3) ["k4"]=> float(4) ["k5"]=> float(5) ["k6"]=> float(6) ["k7"]=> float(7) }
var_dump($redis->zRemRangeByRank('sc1', 0, 3));
echo "<br/>";
//结果int(4)
var_dump($redis->zRange('sc1', 0, -1,true));
echo "<br/>";
//结果 array(3) { ["k5"]=> float(5) ["k6"]=> float(6) ["k7"]=> float(7) }
14.ZREMRANGEBYSCORE
ZREMRANGEBYSCORE key-name min max
移除有序集合中分值介于min 和max 之间的所有成员
php示例
var_dump($redis->zRange('sc1', 0, -1,true));
echo "<br/>";
//结果 array(7) { ["k1"]=> float(1) ["k2"]=> float(2) ["k3"]=> float(3) ["k4"]=> float(4) ["k5"]=> float(5) ["k6"]=> float(6) ["k7"]=> float(7) }
var_dump($redis->zRemRangeByScore('sc1', 0, 3));
echo "<br/>";
//结果int(3)
var_dump($redis->zRange('sc1', 0, -1,true));
echo "<br/>";
//结果 array(4) { ["k4"]=> float(4) ["k5"]=> float(5) ["k6"]=> float(6) ["k7"]=> float(7) }
15.ZINTERSTORE
ZINTERSTORE dest-key key-count key [key……] [WEIGHTS weight[weight……]] [AGGREGATE SUM|MIN|MAX]
对给定的有序集合执行交集运算
有序集合的数量通过key-count指定
WEIGHTS选项,用于指定一个乘法因子,有序集合中每个成员的SCORE值乘以该因子后,结果传递给聚合函数。并且,乘法因子的设置需要根据有序集合的个数分别指定。默认为1。
AGGREGATE选项,用于指定该交集的结果集的聚合方式。默认使用的是SUM
多添加几个元素
min
带weights的
php示例
$redis = new redis();
$redis->connect('127.0.0.1', 6609);
$redis->delete('sc1');
$redis->delete('sc2');
$redis->delete('in');
$redis->delete('in1');
$redis->delete('in2');
$redis -> zAdd('sc1',1,'k1',2,'k2',3,'k3');
$redis -> zAdd('sc2',1,'k1',2,'k2',3,'k3',4,'k4',5,'k5');
var_dump($redis->zRange('sc1', 0, -1,true));
echo "<br/>";
//结果 array(3) { ["k1"]=> float(1) ["k2"]=> float(2) ["k3"]=> float(3) }
var_dump($redis->zRange('sc2', 0, -1,true));
echo "<br/>";
//结果 array(5) { ["k1"]=> float(1) ["k2"]=> float(2) ["k3"]=> float(3) ["k4"]=> float(4) ["k5"]=> float(5) }
var_dump($redis->zInter('in', array('sc1', 'sc2')));
echo "<br/>";
//结果int(3)
var_dump($redis->zRange('in', 0, -1,true));
echo "<br/>";
//结果 array(3) { ["k1"]=> float(2) ["k2"]=> float(4) ["k3"]=> float(6) }
var_dump($redis->zInter('in1', array('sc1', 'sc2'), array(1, 3), 'min'));
echo "<br/>";
//结果 int(3)
var_dump($redis->zRange('in1', 0, -1,true));
echo "<br/>";
//结果 array(3) { ["k1"]=> float(1) ["k2"]=> float(2) ["k3"]=> float(3) }
var_dump($redis->zInter('in2', array('sc1', 'sc2'), array(1, 3), 'max'));
echo "<br/>";
//结果 int(3)
var_dump($redis->zRange('in2', 0, -1,true));
echo "<br/>";
//结果 array(3) { ["k1"]=> float(3) ["k2"]=> float(6) ["k3"]=> float(9) }
16.ZUNIONSTORE
ZUNIONSTORE dest-key key-count key [key……] [WEIGHTS weight[weight……]] [AGGREGATE SUM|MIN|MAX]
对给定的有序集合执行并集运算
有序集合的数量通过key-count指定
WEIGHTS选项,用于指定一个乘法因子,有序集合中每个成员的SCORE值乘以该因子后,结果传递给聚合函数。并且,乘法因子的设置需要根据有序集合的个数分别指定。默认为1。
AGGREGATE选项,用于指定该交集的结果集的聚合方式。默认使用的是SUM。
php示例
$redis = new redis();
$redis->connect('127.0.0.1', 6609);
$redis->delete('sc1');
$redis->delete('sc2');
$redis->delete('un');
$redis->delete('un1');
$redis->delete('un2');
$redis -> zAdd('sc1',1,'k1',2,'k2',3,'k3',8,'k8');
$redis -> zAdd('sc2',1,'k1',2,'k2',3,'k3',4,'k4',5,'k5');
var_dump($redis->zRange('sc1', 0, -1,true));
echo "<br/>";
//结果 array(4) { ["k1"]=> float(1) ["k2"]=> float(2) ["k3"]=> float(3) ["k8"]=> float(8) }
var_dump($redis->zRange('sc2', 0, -1,true));
echo "<br/>";
//结果 array(5) { ["k1"]=> float(1) ["k2"]=> float(2) ["k3"]=> float(3) ["k4"]=> float(4) ["k5"]=> float(5) }
var_dump($redis->zUnion('un', array('sc1', 'sc2')));
echo "<br/>";
//结果int(6)
var_dump($redis->zRange('un', 0, -1,true));
echo "<br/>";
//结果 array(6) { ["k1"]=> float(2) ["k2"]=> float(4) ["k4"]=> float(4) ["k5"]=> float(5) ["k3"]=> float(6) ["k8"]=> float(8) }
var_dump($redis->zUnion('un1', array('sc1', 'sc2'), array(1, 3), 'min'));
echo "<br/>";
//结果 int(6)
var_dump($redis->zRange('un1', 0, -1,true));
echo "<br/>";
//结果 array(6) { ["k1"]=> float(1) ["k2"]=> float(2) ["k3"]=> float(3) ["k8"]=> float(8) ["k4"]=> float(12) ["k5"]=> float(15) }
var_dump($redis->zUnion('un2', array('sc1', 'sc2'), array(1, 3), 'max'));
echo "<br/>";
//结果 int(6)
var_dump($redis->zRange('un2', 0, -1,true));
echo "<br/>";
//结果 array(6) { ["k1"]=> float(3) ["k2"]=> float(6) ["k8"]=> float(8) ["k3"]=> float(9) ["k4"]=> float(12) ["k5"]=> float(15) }
17.ZSCAN
用于迭代有序集合中的元素,包括元素成员与元素分值
ZSCAN key-name CURSOR [MATCH pattern] [COUNT count]
redis的有序集合ZSET(stored set)的更多相关文章
- php使用redis的有序集合zset实现延迟队列
延迟队列就是个带延迟功能的消息队列,相对于普通队列,它可以在指定时间消费掉消息. 延迟队列的应用场景: 1.新用户注册,10分钟后发送邮件或站内信. 2.用户下单后,30分钟未支付,订单自动作废. 我 ...
- 聊聊Mysql索引和redis跳表 ---redis的有序集合zset数据结构底层采用了跳表原理 时间复杂度O(logn)(阿里)
redis使用跳表不用B+数的原因是:redis是内存数据库,而B+树纯粹是为了mysql这种IO数据库准备的.B+树的每个节点的数量都是一个mysql分区页的大小(阿里面试) 还有个几个姊妹篇:介绍 ...
- Redis对象——有序集合(ZSet)
有序集合类型 (Sorted Set或ZSet) 相比于集合类型多了一个排序属性 score(分值),对于有序集合 ZSet 来说,每个存储元素相当于有两个值组成的,一个是有序结合的元素值,一个是排序 ...
- redis 有序集合(zset)函数
redis 有序集合(zset)函数 zAdd 命令/方法/函数 Adds the specified member with a given score to the sorted set stor ...
- 9、Redis五大数据类型---有序集合Zset(sorted set)
一.简介 zset与set异同 相同之处: 都是没有重复元素的字符串集合 不同之处: 有序集合zset的每个成员都关联了一个评分(score),这个评分(score)被用来按照从最低分到最高分的方式排 ...
- [PHP] PHP多个进程配合redis的有序集合实现大文件去重
1.对一个大文件比如我的文件为 -rw-r--r-- 1 ubuntu ubuntu 9.1G Mar 1 17:53 2018-12-awk-uniq.txt 2.使用split命令切割成10 ...
- Redis 操作有序集合数据
Redis 操作有序集合数据: > zadd names "Tom" // zadd 用于往有序集合中添加元素,其中 1 在 Redis 中称为 score(分数),用来进行 ...
- python 操作redis之——有序集合(sorted set) (七)
#coding:utf8 import redis r =redis.Redis(host=") 1.Zadd 命令用于将一个或多个成员元素及其分数值加入到有序集当中.如果某个成员已经是有序 ...
- redis:php-redis中有序集合 zset的使用
ZSET(stored set) 和 set 一样是字符串的集合,不同的是每个元素都会关联一个 double 类型的 score .实现使用的是 skip list 和 hash table , sk ...
随机推荐
- [转]【MySQL】关于时间的查询,比如本月,本年,本季度
原文地址:https://www.cnblogs.com/flydkPocketMagic/p/7089324.html -- mysql查询本季度 -- 今天 select * from ticke ...
- [转]JAVA反射中的getFields()方法和getDeclaredFields ()方法的区别
关于获取类的字段有两种方式:getFields()和getDeclaredFields().我们先来看看这两者的区别吧: getFields():获得某个类的所有的公共(public)的字段,包括父类 ...
- JTree常用方法
private JTree jtNetDevice;//数组件申明private JScrollPane jspTree;//滚动面板申明 1.初始化 DefaultMutableTreeNo ...
- WIN7下重建图标缓存(解决MFC.exe桌面图标显示异常问题)
WIN7下重建图标缓存 使用WIN7时,MFC工程生成的应用程序图标,如果更改为自定义的ICON图标之后可能在桌面上显示的依旧是上一次的图标,改个名或换个路径都能恢复正常,说明在WIN7系统下图标的缓 ...
- 如何修改被hosts.deny禁止访问的IP
自己的密码忘记了,重试了很多次被加入了黑名单. 如果仅仅清空 /etc/hosts.deny 文件内容,你会发现过一会自己的IP又进入里面了. 其实系统后台会定期自动扫描一些文件,然后将这些异常的IP ...
- elasticsearch6.4 memory locking requested for elasticsearch process but memory is not locked 终极解决
echo "es hard memlock unlimited">>/etc/security/limits.confecho "es soft memloc ...
- 将url参数转为json对象
/** * 将url参数转为json对象 * * @param str * @returns {{}} */ function parseQueryString(str){ arr = [], len ...
- spring security笔记
当指定http元素的auto-config=”true”时,就相当于如下内容的简写. <security:http> <security:form-login/> <se ...
- flarum论坛系统搭建教程
安装 PHP 5.5+ and MySQL 5.5+, and install Composer. composer create-project flarum/flarum . --stabilit ...
- nodejs应用在linux服务器中的部署
1.(可选)添加用户: addgroup wmui添加用户组useradd -d /home/wmui -s /bin/bash -m wmui创建wmui用户passwd wmui设置密码,如果忘记 ...