使用Jedis操作Redis-使用Java语言在客户端操作---对Sorted-Sets的操作
//对Sorted-Sets操作
/**
* Sorted-Sets和Sets类型极为相似,它们都是字符串的集合,都不允许重复的成员出现在一个Set中。
* 它们之间的主要差别是Sorted-Sets中的每一个成员都会有一个分数(score)与之关联,Redis正是通过分数来为集合中的成员进行从小到大的排序。
* 然而需要额外指出的是,尽管Sorted-Sets中的成员必须是唯一的,但是分数(score)却是可以重复的。
* 在Sorted-Set中添加、删除或更新一个成员都是非常快速的操作,其时间复杂度为集合中成员数量的对数。
* 由于Sorted-Sets中的成员在集合中的位置是有序的,因此,即便是访问位于集合中部的成员也仍然是非常高效的。
* @throws Exception
*/
@Test
public void testSorted_Sets() throws Exception {
jedis.flushAll(); //添加一个分数为1的成员
jedis.zadd("myzset", 1, "one"); Map<String,Double> map = new LinkedHashMap<String,Double>();
map.put("two", (double) 2);
map.put("three", (double) 3);
//添加两个分数分别是2和3的两个成员。
jedis.zadd("myzset", map);//这个单独测一下 //0表示第一个成员,-1表示最后一个成员。返回的结果中包含每个成员
Set<String> zrange = jedis.zrange("myzset", 0, -1);
System.out.println("zrange="+zrange);//zrange=[one, two, three] //获取成员one在Sorted-Set中的位置索引值。0表示第一个位置
Long zrank = jedis.zrank("myzset", "one");
System.out.println("zrank = "+zrank);//zrank = 0 //成员four并不存在,因此返回null
System.out.println(jedis.zrank("myzset", "four"));//null //#返回与myzset关联的Sorted-Set中,分数满足表达式1 <= score <= 2的成员的数量。
Long zcount = jedis.zcount("myzset", 1, 2);
System.out.println("zcount="+zcount);//zcount=2 //获取myzset键中成员的数量。
System.out.println(jedis.zcard("myzset"));//3 //删除成员one和two,返回实际删除成员的数量。
Long zrem = jedis.zrem("myzset", "one","two");
System.out.println("zrem="+zrem);//zrem=2 //查看是否删除成功。 获取键中成员的数量
System.out.println(jedis.zcard("myzset"));//1 //获取成员three的分数。返回值是字符串形式。
Double zscore = jedis.zscore("myzset", "three");
System.out.println("zscore="+zscore);//zscore=3.0 //由于成员two已经被删除,所以该命令返回null
System.out.println(jedis.zscore("myzset", "two"));//null //将成员three的分数增加2,并返回该成员更新后的分数。
Double zincrby = jedis.zincrby("myzset", 2, "three");
System.out.println("zincrby="+zincrby);//zincrby=5.0 //将成员three的分数增加-1,并返回该成员更新后的分数。
System.out.println(jedis.zincrby("myzset", -1, "three"));//4.0 //====================》》》》》》
jedis.del("myzset"); Map<String,Double> map3 = new LinkedHashMap<String,Double>();
map3.put("one", 1.0);
map3.put("two", 2.0);
map3.put("three", 3.0);
map3.put("four", 4.0);
//一次添加多个
jedis.zadd("myzset",map3); //获取分数满足表达式1 <= score <= 2的成员。
Set<String> zrangeByScore = jedis.zrangeByScore("myzset", 1, 2);
System.out.println("zrangeByScore= "+zrangeByScore);////zrangeByScore= [one, two] //删除分数满足表达式1 <= score <= 2的成员,并返回实际删除的数量。
Long zremrangeByScore = jedis.zremrangeByScore("myzset", 1, 2);
System.out.println("zremrangeByScore="+zremrangeByScore);//zremrangeByScore=2 //看出一下上面的删除是否成功。
System.out.println(jedis.zrange("myzset", 0, -1));//[three, four] //删除位置索引满足表达式0 <= rank <= 1的成员。返回实际删除的数量
Long zremrangeByRank = jedis.zremrangeByRank("myzset", 0, 1);
System.out.println("zremrangeByRank="+zremrangeByRank);//zremrangeByRank=2 //查看上一条命令是否删除成功。
Long zcard = jedis.zcard("myzset");
System.out.println("zcard = "+zcard);//zcard = 0 //======================>>>>>>>>>>>>>>>>> jedis.del("myzset");
Map<String,Double> map2 = new LinkedHashMap<String,Double>();
map2.put("one", 1.0);
map2.put("two", 2.0);
map2.put("three", 3.0);
map2.put("four", 4.0);
//一次添加多个
jedis.zadd("myzset",map2); //以位置索引从高到低的方式获取并返回此区间内的成员。
Set<String> zrevrange = jedis.zrevrange("myzset", 0, -1);
System.out.println("zrevrange="+zrevrange);//zrevrange=[four, three, two, one] Set<String> zrevrange2 = jedis.zrevrange("myzset", 1, 3);
System.out.println("zrevrange2="+zrevrange2);//zrevrange2=[three, two, one] //由于是从高到低的排序,所以one的位置是3。
System.out.println(jedis.zrevrank("myzset", "one"));//3 //由于是从高到低的排序,所以four的位置是0。
System.out.println(jedis.zrevrank("myzset", "four"));//0 //获取分数满足表达式3 >= score >= 0的成员,并以相反的顺序输出,即从高到底的顺序。
System.out.println(jedis.zrevrangeByScore("myzset", 3, 0));//[three, two, one] System.out.println("数据:="+jedis.zrange("myzset", 0, -1));//数据:=[one, two, three, four] /**
* zrangeByScoreWithScores(String key, double min, double max, int offset, int count)
* key:键
* min:最小分值
* max:最大分值
* offset:偏移量,也就是从哪个位置开始。
* count:元素个数
*
* 返回的元素用ASCII码表示的,该元素的值用double类型数据表示
*/
System.out.println(jedis.zrangeByScoreWithScores("myzset", 2, 3, 0, 2));//[[[116, 119, 111],2.0], [[116, 104, 114, 101, 101],3.0]] }
使用Jedis操作Redis-使用Java语言在客户端操作---对Sorted-Sets的操作的更多相关文章
- 使用Jedis操作Redis-使用Java语言在客户端操作---set类型
原文地址:http://www.cnblogs.com/lixianyuan-org/p/9509696.html 1 //测试set数据类型 2 /** 3 * 在Redis中,我们可以将Set类型 ...
- 使用Jedis操作Redis-使用Java语言在客户端操作---hash类型
我们可以将Redis中的Hashes类型看成具有String Key和String Value的map容器. 所以该类型非常适合于存储值对象的信息.如Username.P ...
- 使用Jedis操作Redis-使用Java语言在客户端操作---List类型
在Redis中,List类型是按照插入顺序排序的字符串链表.和数据结构中的普通链表一样,我们可以在其头部(left)和尾部(right)添加新的元素.在插入时,如果该键并不存在,Redis将为该键创建 ...
- 使用Jedis操作Redis-使用Java语言在客户端操作---String类型
前提:需要引入Jedis的jar包. /** * 我的redis在Linux虚拟机Centos7中,192.168.222.129是我虚拟机的ip地址. */ private static Jedis ...
- 使用Jedis操作Redis-使用Java语言在客户端操作---对key的操作
//添加String类型的模拟数据. jedis.set("mykey", "2"); jedis.set("mykey2", " ...
- 使用Java(Jedis)链接redis报java.net.ConnectException: Connection refused: connect的错误
redis环境:centos6 java代码运行环境:windows 第一种情况:未开启redis服务. redis-server /myredis/redis.conf (写你的redis配置文件的 ...
- [java学习笔记]java语言基础概述之数组的定义&常见操作(遍历、排序、查找)&二维数组
1.数组基础 1.什么是数组: 同一类型数据的集合,就是一个容器. 2.数组的好处: 可以自动为数组中的元素从零开始编号,方便操作这些数据. 3.格式: (一 ...
- 使用jedisPool管理jedis,使用jedis操作redis
ps:jedis是redis在java中的客户端操作工具 package com.test; 2 3 import java.util.HashMap; 4 import java.util.Iter ...
- Jedis测试redis
首先:Jedis是redis的java版本的客户端. public class JedisTest { //单机版测试Jedis,不使用连接池 @Test public void testJedis( ...
随机推荐
- 记 openSUSE 42.3 升级到Leap 15.0
先将系统的软件更新到最新版本 sudo zypper update 删除42.3的软件源,若有其他数据源,如nginx的,也需要一并删除,可使用zypper lr -d 来查询 sudo zypper ...
- Java虚拟机笔记
Java内存区域划分 1.程序计数器 线程私有,当前线程执行的行号指示器,指向当前线程执行的虚拟机字节码地址,线程的恢复,跳转等都需要用到它 2.Java虚拟机栈 线程私有,虚拟机栈描述的是Java内 ...
- 进程互斥软件实现之Dekker算法
一. 为什么需要互斥? 大多数系统允许多个进程共享资源(如CPU,IO设备,硬盘等), 为了保证进程间能够互不影响.安全正确地访问这些共享资源, 就必须对进程访问共享资源采取互斥控制. 进程互斥原则: ...
- leetcode-03-二叉树的锯齿层次遍历
题目描述: 方法一: # Definition for a binary tree node. # class TreeNode: # def __init__(self, x): # self.va ...
- 2016.10.7初中部上午NOIP普及组比赛总结
2016.10.7初中部上午NOIP普及组比赛总结 这次的题还可以,重新入了比赛的前十. 进度: 比赛:90+10+70+30=200 改题:AC+AC+AC+AC=AK 找试场 这题很简单,但是被欺 ...
- TmodJs:常用语法
ylbtech-TmodJs:常用语法 1.返回顶部 1.循环 {{each items as item index}} <tr> <td>{{index+1}}</td ...
- linux中断处理-顶半部(top half)和底半部(bottom half) -转
原文:http://rensanshi.blog.163.com/blog/static/21395510820136282224877/ 设备的中断会打断内核中进程的正常调度和运行,系统对更高吞吐率 ...
- <每日一题>题目10:求斐波拉契数列
def func(x): m,n = 0,1 i = 0 while i < x: yield m m,n = n,m+n i += 1 fib = [] get_func = func(100 ...
- reac-native + typescript 的环境搭建
一. RN-TS环境搭建 . 安装RN脚手架 yarn add create-react-native-app -g yarn global add typescript . 创建项目文件夹 crea ...
- MFC安装与部署(程序打包)
(发现csdn传照片实在是太麻烦, 不能够直接拖拽进来;所以我直接使用云笔记生成一张图片 直接完成!) (懒癌晚期-)