Redis学习笔记-List

Posted 左侧码工

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Redis学习笔记-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学习笔记-List的主要内容,如果未能解决你的问题,请参考以下文章

Redis深入学习笔记client list 命令详解

Redis学习笔记- 基础篇-基础结构及语法

Redis笔记 Redis数据结构 - list链表

Redis笔记 Redis数据结构 - list链表

Redis6学习笔记(自用)

Redis学习笔记