public Long zcount(String key, double min, double max) {
Jedis jedis = null;
try {
jedis = jedisPool.getResource();
return jedis.zcount(key, min, max);
} catch (Exception e) {
log.error(e.getMessage());
return 0L;
} finally {
returnResource(jedisPool, jedis);
(3)返回有序集合指定成员的索引
相关命令:
127.0.0.1:6379> zrange user:5 0 -1 (正序,0,-1返回所有)
1) "黄鹤楼"
2) "金陵十二钗"
127.0.0.1:6379> zrank user:5 金陵十二钗 (获取索引)
(integer) 1
(4)通过索引区间返回有序集合指定区间内的成员
相关命令:
127.0.0.1:6379>
zrange user:5 0 -1 (正序,0,-1返回所有)
1) "黄鹤楼"
2) "金陵十二钗"
127.0.0.1:6379> zrevrange user:5 0 -1(倒序,0,-1返回所有)
1) "金陵十二钗"
2) "黄鹤楼"
(5)通过分数返回有序集合指定区间的成员
相关命令:
127.0.0.1:6379> zrangebyscore user:5 0 77
1) "黄鹤楼"
127.0.0.1:6379> zrangebyscore user:5 77 88
1) "黄鹤楼"
2) "金陵十二钗"
(6)返回索引
127.0.0.1:6379>zrank user:5 金陵十二钗
(integer) 1
(1)移除集合
127.0.0.1:6379> del user:4
(integer) 1
127.0.0.1:6379> zrange z1 0 -1
(empty list or set)
(2)移除集合中的一个或多个成员
127.0.0.1:6379> zrange user:5 0 -1
1) "黄鹤楼"
2) "金陵十二钗"
127.0.0.1:6379> zrem user:5 黄鹤楼
(integer) 1
127.0.0.1:6379> zrange user:5 0 -1
1) "金陵十二钗"
(3)移除有序集合中给定的排名区间的所有成员
127.0.0.1:6379> zadd user:4 1 白沙 4 万宝路
(integer) 2
127.0.0.1:6379> zremrangebyrank user:4 0 1
(integer) 2
127.0.0.1:6379> zrange user:4 0 -1
redisUtils.zremrangeByRank(key, 0, -1, RedisConstants.datebase2);
(4)根据分数区间删除
zadd user:4 1 白沙 4 万宝路 18 南京
127.0.0.1:6379> zrange user:4 0 -1
1) "白沙"
2) "万宝路"
3) "南京"
127.0.0.1:6379> zremrangebyscore user:4 1 5
(integer) 2
127.0.0.1:6379> zrange user:4 0 -1
1) "南京"
5、增加分数
(1)增加元素的分组,返回值是更改后的分数:
127.0.0.1:6379> zrange user:4 0 -1
1) "白沙"
2) "万宝路"
3) "南京"
127.0.0.1:6379> zincrby user:4 100 白沙
127.0.0.1:6379> zrange user:4 0 -1
1) "万宝路"
2) "南京"
3) "白沙"
zadd(key, score, member):向名称为key的zset中添加元素member,score用于排序。如果该元素已经存在,则根据score更新该元素的顺序。
zrem(key, member) :删除名称为key的zset中的元素member
zincrby(key, increment, member) :如果在名称为key的zset中已经存在元素member,则该元素的score增加increment;否则向集合中添加该元素,其score的值为increment
zrank(key, member) :返回名称为key的zset(元素已按score从小到大排序)中member元素的rank(即index,从0开始),若没有member元素,返回“nil”
zrevrank(key, member) :返回名称为key的zset(元素已按score从大到小排序)中member元素的rank(即index,从0开始),若没有member元素,返回“nil”
zrange(key, start, end):返回名称为key的zset(元素已按score从小到大排序)中的index从start到end的所有元素
zrevrange(key, start, end):返回名称为key的zset(元素已按score从大到小排序)中的index从start到end的所有元素
zrangebyscore(key, min, max):返回名称为key的zset中score >= min且score <= max的所有元素 zcard(key):返回名称为key的zset的基数,有几条数据
zscore(key, element):返回名称为key的zset中元素element的score
zremrangebyrank(key, min, max):删除名称为key的zset中rank >= min且rank <= max的所有元素 zremrangebyscore(key, min, max) :删除名称为key的zset中score >= min且score <= max的所有元素
Redis 有序集合和集合一样也是 string 类型元素的集合,且不允许重复的成员。不同的是每个元素都会关联一个 double 类型的分数。redis 正是通过分数来为集合中的成员进行从小到大的排序。有序集合的成员是唯一的,但分数(score)却可以重复。集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是 O(1)。 集合中最大的成员数为 232- 1 (4294967295, 每个集合可存储40多亿个成员)。...
如果使用redis zset结构,key不能直接设置过期时间,又想对member设置过期删除时,可以使用这个脚本根据score进行过期删除。大家可以参考下,score的格式需要自定义调整下。
删除脚本redis-del-keys.sh (main)
#!/bin/bash
##redis主机IP
host=$1
##redis端口
port=$2
##redis端口
password=$3
##r...
我已经对该库进行了3年以上的维护,但是我没有足够的时间来提供可靠的支持和持续的开发。
任何现有的或新的问题将不予处理,我不保证合并任何新的请求请求。
如果有人愿意接管此项目,请随时分叉此项目,并给我发消息以在此自述文件中添加指向您的分叉的链接。
cpp_redis
cpp_redis是C ++ 11异步多平台轻量级Redis客户端,支持同步操作,流水线,标记和高可用性。
cpp_redis没有依赖项。 它唯一的要求是C++11 。
它没有网络模块,因此您可以自由配置自己的模块,也可以使用默认模块( )
cpp_redis :: client
cpp_redis::client client;
client.connect();
client.set( " hello " , " 42 " );
client.get( " hello " , [](cpp_redis::reply& reply) {
std::cout << reply << std::endl;
// ! also sup
redis之Zset操作
集合Zset:在set基础上加了一个score。
Zset设置:ZADD zset01 60 v1 70 v2 80 v3 90 v4 100 v5
Zset获取等级:ZRANGE zset01 0 -1
Zset逆序获取等级:ZREVRANGE zset01 0 -1
Zset获取分数和等级:ZRANGE zset01 0 -1 withscores
127.0.0.1:6379[1]> ZADD zset01 60 v1 70 v2 80 v3 90 v4 1
1、zadd :添加元素,格式是:zadd zset的key score值 项的值, Score和项可以是多对,score可以是整数,也可以是浮点数,还可以是+inf表示无穷大,-inf表示负无穷大
操作如下:
java示例代码:
import redis.clients.jedis.Jedis;
import java.util.HashMap;
import java.util.Map;
* redis中对于ZSet类型的: zadd 操作示例
* zadd :添加...
Redis的基本数据类型一、字符串类型及其操作二、hash类型及其操作三、list类型及操作set类型及操作应用范围:应用案例1:zset类型和操作应用范围:key命令的使用
一、字符串类型及其操作
字符串类型是Redis中最为基础的数据存储类型,它在Redis中是二进制安全的,这便意味着该类型可以接受任何格式的数据,如JPEG图像数据或Json对象描述信息等。在Redis中字符串类型的Value最多可以
容纳的数据长度是512M。
SET key value:将key设置成指定字符串,如果存在就覆盖原有值
Redis ZSet(Sorted Set)是一种带权重的有序集合。在 Redis 中,每个元素都有一个分数,用于排序。ZSet 的成员是唯一的,但分数(score)可以相同。
ZSet 的底层实现使用了跳跃表(skip list),这是一种用于快速排序的数据结构。因此,ZSet 可以在常数时间内执行插入、删除和查找操作。
你可以使用 ZSet 来实现排行榜、消息时间线等功能。它还可以用于范围查询,例如查找排名前 10 的用户。