Redis学习笔记(4)-List
package cn.com; import java.util.List; import redis.clients.jedis.Jedis;
import redis.clients.jedis.BinaryClient.LIST_POSITION; public class Redis_List {
public static Jedis redis = new Jedis("localhost", 6379);// 连接redis /**
* 返回列表 key 中指定区间内的元素,区间以偏移量 start 和 stop 指定。
* */
public static void lrange(){
redis.flushDB();//清除数据
/**初始化数据*/
redis.lpush("languages", "english","chain");
redis.lpush("languages", "english"); /**取数据*/
List<String> list=redis.lrange("languages", 0, -1);
for(String s:list){
System.out.println("s:"+s);
}
}
/**
* 将一个或多个值 value 插入到列表 key 的表头
* 如果有多个 value 值,那么各个 value 值按从左到右的顺序依次插入到表头:
* 如果 key 不存在,一个空列表会被创建并执行 LPUSH 操作。
* 当 key 存在但不是列表类型时,返回一个错误。
* */
public static void lpush(){
redis.flushDB();//清除数据
redis.lpush("languages", "english","chain");
redis.lpush("languages", "english");//加入重复元素
redis.lpush("languages", "1","2","3");
List<String> list=redis.lrange("languages", 0, -1);
for(String s:list){
System.out.println("s:"+s);
} } /**
* LPUSHX key value
* 将值 value 插入到列表 key 的表头,当且仅当 key 存在并且是一个列表。
* 和 LPUSH 命令相反,当 key 不存在时, LPUSHX 命令什么也不做。
* */
public static void lpushx(){
redis.flushDB();//清除数据
redis.lpushx("languages", "english");
List<String> list=redis.lrange("languages", 0, -1);
for(String s:list){
System.out.println("s:"+s);
}
} /**
* RPUSH key value [value ...]
* 将一个或多个值 value 插入到列表 key 的表尾(最右边)。
* 如果 key 不存在,一个空列表会被创建并执行 RPUSH 操作。
* 当 key 存在但不是列表类型时,返回一个错误。
* */
public static void rpush(){
redis.flushDB();//清除数据
redis.rpush("languages", "english","chain");
redis.rpush("languages", "english");//加入重复元素
redis.rpush("languages", "1","2","3");//加入重复元素
List<String> list=redis.lrange("languages", 0, -1);
for(String s:list){
System.out.println("s:"+s);
}
} /**
* LPUSHX key value
* 将值 value 插入到列表 key 的尾,当且仅当 key 存在并且是一个列表。
* 和 LPUSH 命令相反,当 key 不存在时, LPUSHX 命令什么也不做。
* */
public static void rpushx(){
redis.flushDB();//清除数据
redis.rpush("languages", "1","2","3");//加入重复元素
redis.rpushx("languages", "english");
List<String> list=redis.lrange("languages", 0, -1);
for(String s:list){
System.out.println("s:"+s);
}
} /**
* 移除并返回列表 key 的头元素。
* 当 key 不存在时,返回 nil 。
* */
public static void lpop(){
redis.flushDB();//清除数据
redis.lpush("languages", "1","2","3","4","5");
String str=redis.lpop("languages");
List<String> list=redis.lrange("languages", 0, -1); System.out.println("被移除的元素:"+str); System.out.println("剩下的元素列表:");
for(String s:list){
System.out.print(""+s+" ");
}
} /**
* 移除并返回列表 key 的尾元素。
* 当 key 不存在时,返回 nil 。
* */
public static void rpop(){
redis.flushDB();//清除数据
redis.lpush("languages", "1","2","3","4","5");
String str=redis.rpop("languages");
List<String> list=redis.lrange("languages", 0, -1); System.out.println("被移除的元素:"+str); System.out.println("剩下的元素列表:");
for(String s:list){
System.out.print(""+s+" ");
}
} /**
* 如果给定 key 内至少有一个非空列表,那么弹出遇到的第一个非空列表的头元素,
* 并和被弹出元素所属的列表的名字一起,组成结果返回给调用者
* */
public static void blpop(){
redis.flushDB();//清除数据
//redis.lpush("languages", "a","b","c","d","e");//初始化数据
redis.lpush("base", "a","b","c","d");//初始化数据
List<String> list=redis.blpop(1000,"base");
for(String s:list){
System.out.println(s+" ");
}
List<String> list2=redis.lrange("base", 0, -1);
for(String s:list2){
System.out.println("剩余"+s+" ");
}
} /**
* 如果给定 key 内至少有一个非空列表,那么弹出遇到的第一个非空列表的尾元素,
* 并和被弹出元素所属的列表的名字一起,组成结果返回给调用者
* */
public static void brpop(){
redis.flushDB();//清除数据 redis.lpush("base", "a","b","c","d");//初始化数据
List<String> list=redis.brpop(1000,"base");
for(String s:list){
System.out.println(s+" ");
}
List<String> list2=redis.lrange("base", 0, -1);
for(String s:list2){
System.out.println("剩余"+s+" ");
}
} /**
* 从头部弹出一个元素,将弹出的数据放入新的数组中 与方法 (rpoplpush)相同使用
* 当列表 source 为空时, BRPOPLPUSH 命令将阻塞连接,直到等待超时,或有另一个客户端对 source 执行 LPUSH 或 RPUSH 命令为止。
* 超时参数 timeout 接受一个以秒为单位的数字作为值。超时参数设为 0 表示阻塞时间可以无限期延长(block indefinitely) 。
* */
public static void brpoplpush(){
redis.flushDB();//清除数据
redis.lpush("base", "a","b","c","d");//初始化数据
String s=redis.brpoplpush("base", "dest",0); System.out.println("s:"+s);
List<String> list=redis.lrange("base", 0, -1);
for(String str:list){
System.out.println("base list"+str+" ");
}
List<String> list1=redis.lrange("dest", 0, -1);
for(String str:list1){
System.out.println("dest list:"+str+" ");
}
} /**
* 从头部弹出一个元素,将弹出的数据放入新的数组中
* */
public static void rpoplpush(){
redis.flushDB();//清除数据
redis.lpush("base", "a","b","c","d");//初始化数据
String s=redis.rpoplpush("base", "dest");
System.out.println("弹出的元素:"+s);
List<String> list=redis.lrange("base", 0, -1);
for(String str:list){
System.out.println("base list"+str+" ");
}
List<String> list1=redis.lrange("dest", 0, -1);
for(String str:list1){
System.out.println("dest list:"+str+" ");
}
} /**
* LREM key count value
* 根据参数 count 的值,移除列表中与参数 value 相等的元素。
* count > 0 : 从表头开始向表尾搜索,移除与 value 相等的元素,数量为 count 。
* count < 0 : 从表尾开始向表头搜索,移除与 value 相等的元素,数量为 count 的绝对值。
* count = 0 : 移除表中所有与 value 相等的值。
* */
public static void lrem(){
redis.flushDB();//清除数据
redis.lpush("base", "a","b","c","d","e","f","g","h");//初始化数据 Long index=redis.lrem("base", 0, "a");//移除与 集合里面有a的元素
System.out.println(index); List<String> list=redis.lrange("base", 0, -1);
System.out.println("========剩余元素==========");
for(String str:list){
System.out.println( str+" ");
}
} /**
* LSET key index value
*将列表 key 下标为 index 的元素的值设置为 value 。
*当 index 参数超出范围,或对一个空列表( key 不存在)进行 LSET 时,返回一个错误。
* */
public static void lset(){
redis.flushDB();//清除数据
redis.lpush("base", "a","b","c","d","e","f","g","h");//初始化数据
redis.lset("base", 6, "2b");//将b元素设置为2b List<String> list=redis.lrange("base", 0, -1);
for(String s:list){
System.out.println(s);
}
} /**
* 让列表只保留指定区间内的元素,不在指定区间之内的元素都将被删除。
* 举个例子,执行命令 LTRIM list 4 6 ,表示只保留列表 list 的4 到 6 元素,其余元素全部删除。
* */
public static void ltrim(){
redis.flushDB();//清除数据
String [] s=new String[]{"a","b","c","d","e","f","g","h"};
redis.lpush("base", s);//初始化数据
redis.ltrim("base", 4, 6);//值保留b,c,d 对应的索引是4,5,6 多有被保留下来 List<String> list=redis.lrange("base", 0, -1);
for(String str:list){
System.out.println(str);
}
} /**
* 返回列表 key 的长度。
* 如果 key 不存在,则 key 被解释为一个空列表,返回 0 .
* 如果 key 不是列表类型,返回一个错误
* */
public static void llen(){
redis.flushDB();//清除数据
redis.lpush("base", "a","b","c","d","e","f","g","h");//初始化数据 Long length=redis.llen("base");
System.out.println("长度:"+length);
} /**
* 返回列表 key 中,下标为 index 的元素。
* 下标(index)参数 start 和 stop 都以 0 为底,也就是说,以 0 表示列表的第一个元素,以 1 表示列表的第二个元素,以此类推。
* 你也可以使用负数下标,以 -1 表示列表的最后一个元素, -2 表示列表的倒数第二个元素,以此类推。
* 如果 key 不是列表类型,返回一个错误。
* */
public static void lindex(){
redis.flushDB();//清除数据
redis.lpush("base", "a","b","c","d","e","f","g","h");//初始化数据
String s=redis.lindex("base", 2);
System.out.println(s);
} /**
* LINSERT key BEFORE|AFTER pivot value
* 将值 value 插入到列表 key 当中,位于值 pivot 之前或之后。
* 当 pivot 不存在于列表 key 时,不执行任何操作。pivot 指的数组中的元素
* 当 key 不存在时, key 被视为空列表,不执行任何操作。
* 如果 key 不是列表类型,返回一个错误。
* */
public static void linsert(){
redis.flushDB();//清除数据
redis.lpush("base", "a","b","c","d","e","f","g","h");//初始化数据
redis.linsert("base", LIST_POSITION.BEFORE, "b", "2b");//在b 之前插入2b
//redis.linsert("base", LIST_POSITION.AFTER, "b", "2b");//在b 之后插入2b
List<String> list=redis.lrange("base", 0, -1);
for(String str:list){
System.out.println(str);
} } public static void main(String [] args){ linsert();
}
}
Redis学习笔记(4)-List的更多相关文章
- redis 学习笔记(6)-cluster集群搭建
上次写redis的学习笔记还是2014年,一转眼已经快2年过去了,在段时间里,redis最大的变化之一就是cluster功能的正式发布,以前要搞redis集群,得借助一致性hash来自己搞shardi ...
- Redis学习笔记~目录
回到占占推荐博客索引 百度百科 redis是一个key-value存储系统.和Memcached类似,它支持存储的value类型相对更多,包括string(字符串).list(链表).set(集合). ...
- Redis学习笔记4-Redis配置详解
在Redis中直接启动redis-server服务时, 采用的是默认的配置文件.采用redis-server xxx.conf 这样的方式可以按照指定的配置文件来运行Redis服务.按照本Redi ...
- Redis学习笔记7--Redis管道(pipeline)
redis是一个cs模式的tcp server,使用和http类似的请求响应协议.一个client可以通过一个socket连接发起多个请求命令.每个请求命令发出后client通常会阻塞并等待redis ...
- Redis学习笔记一:数据结构与对象
1. String(SDS) Redis使用自定义的一种字符串结构SDS来作为字符串的表示. 127.0.0.1:6379> set name liushijie OK 在如上操作中,name( ...
- Redis学习笔记之ABC
Redis学习笔记之ABC Redis命令速查 官方帮助文档 中文版本1 中文版本2(反应速度比较慢) 基本操作 字符串操作 set key value get key 哈希 HMSET user:1 ...
- (转)redis 学习笔记(1)-编译、启动、停止
redis 学习笔记(1)-编译.启动.停止 一.下载.编译 redis是以源码方式发行的,先下载源码,然后在linux下编译 1.1 http://www.redis.io/download 先 ...
- Redis学习笔记(二)-key相关命令【转载】
转自 Redis学习笔记(二)-key相关命令 - 点解 - 博客园http://www.cnblogs.com/leny/p/5638764.html Redis支持的各种数据类型包括string, ...
- Redis学习笔记(三)Redis支持的5种数据类型的总结
继续Redis学习笔记(二)来说说剩余的三种数据类型. 三.列表类型(List) 1.介绍 列表类型可以存储一个有序的字符串列表,常用的操作是向列表两端添加元素,或者获得列表的一段片段.列表类型内部是 ...
- Redis学习笔记(二)Redis支持的5种数据类型的总结之String和Hash
引言 在Redis学习笔记(一)中我们已经会安装并且简单使用Redis了,接下来我们一起来学习下Redis支持的5大数据类型. 简介 Redis是REmote DIctionary Server(远程 ...
随机推荐
- aaaaaaaaaaaaaa
方法和事件的区别是? For(var 0 in file) Foreach(var i=0;i<length.i++) Git stash Git pull –rebase origin bra ...
- PDA手持终端集成一体打印 二次开发
PDA手持终端集成一体打印 二次开发支持 VS2008或VS2005开发工具 c#或C++开发语言 Mobile6.5,支持GSM通话,GPRS,EDGE网络;内置wifi,蓝牙,gps商场单品管理小 ...
- 简单几何(线段相交) POJ 1410 Intersection
题目传送门 题意:一个矩形和一条线段,问是否有相交 分析:考虑各种情况.坑点:给出的矩形的两个端点是无序的,还有线段完全在矩形内也算相交 /****************************** ...
- 递推DP POJ 1163 The Triangle
题目传送门 题意:找一条从顶部到底部的一条路径,往左下或右下走,使得经过的数字和最大. 分析:递推的经典题目,自底向上递推.当状态保存在a[n][j]时可省去dp数组,空间可优化. 代码1: /*** ...
- hadoop2.2.0部署
hadoop2.2.0部署 下载安装包 hadoop-2.2.0-cdh5.0.0-beta-1.tar.gz 解压 tar zxvf hadoop-2.2.0-cdh5.0.0-beta-1.tar ...
- 什么是J2EE,包括哪些规范!
J2EE平台由一整套服务(Services).应用程序接口(APIs)和协议构成,它对开发基于Web的多层应用提供了功能支持,下面对J2EE中的13种技术规范进行简单的描述(限于篇幅,这里只能进行简单 ...
- pdf转能编辑的word的方法
方法一:用汉王ocr文字识别软件,扫描文字,一页一页扫描,复制粘贴 方法二:将pdf文件拷贝到没有pdf阅读器的电脑上,同时你的office是2013,用word打开你的pdf文档,根据他的提示操作, ...
- [转]asp.net mvc 从数据库中读取图片
本文转自:http://www.cnblogs.com/mayt/archive/2010/05/20/1740358.html 首先是创建一个类,继承于ActionResult,记住要引用Syste ...
- java--测体重练习
public class tz{ public static void main(String[] args){ int sg=165,tz=52;bz = sg-115 if (tz-bz>3 ...
- NOJ 1651 Red packet(二分)
[1651] Red packet 时间限制: 1000 ms 内存限制: 65535 K 问题描述 New Year is coming! Our big boss Wine93 will dist ...