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的更多相关文章

  1. redis 学习笔记(6)-cluster集群搭建

    上次写redis的学习笔记还是2014年,一转眼已经快2年过去了,在段时间里,redis最大的变化之一就是cluster功能的正式发布,以前要搞redis集群,得借助一致性hash来自己搞shardi ...

  2. Redis学习笔记~目录

    回到占占推荐博客索引 百度百科 redis是一个key-value存储系统.和Memcached类似,它支持存储的value类型相对更多,包括string(字符串).list(链表).set(集合). ...

  3. Redis学习笔记4-Redis配置详解

    在Redis中直接启动redis-server服务时, 采用的是默认的配置文件.采用redis-server   xxx.conf 这样的方式可以按照指定的配置文件来运行Redis服务.按照本Redi ...

  4. Redis学习笔记7--Redis管道(pipeline)

    redis是一个cs模式的tcp server,使用和http类似的请求响应协议.一个client可以通过一个socket连接发起多个请求命令.每个请求命令发出后client通常会阻塞并等待redis ...

  5. Redis学习笔记一:数据结构与对象

    1. String(SDS) Redis使用自定义的一种字符串结构SDS来作为字符串的表示. 127.0.0.1:6379> set name liushijie OK 在如上操作中,name( ...

  6. Redis学习笔记之ABC

    Redis学习笔记之ABC Redis命令速查 官方帮助文档 中文版本1 中文版本2(反应速度比较慢) 基本操作 字符串操作 set key value get key 哈希 HMSET user:1 ...

  7. (转)redis 学习笔记(1)-编译、启动、停止

    redis 学习笔记(1)-编译.启动.停止   一.下载.编译 redis是以源码方式发行的,先下载源码,然后在linux下编译 1.1 http://www.redis.io/download 先 ...

  8. Redis学习笔记(二)-key相关命令【转载】

    转自 Redis学习笔记(二)-key相关命令 - 点解 - 博客园http://www.cnblogs.com/leny/p/5638764.html Redis支持的各种数据类型包括string, ...

  9. Redis学习笔记(三)Redis支持的5种数据类型的总结

    继续Redis学习笔记(二)来说说剩余的三种数据类型. 三.列表类型(List) 1.介绍 列表类型可以存储一个有序的字符串列表,常用的操作是向列表两端添加元素,或者获得列表的一段片段.列表类型内部是 ...

  10. Redis学习笔记(二)Redis支持的5种数据类型的总结之String和Hash

    引言 在Redis学习笔记(一)中我们已经会安装并且简单使用Redis了,接下来我们一起来学习下Redis支持的5大数据类型. 简介 Redis是REmote DIctionary Server(远程 ...

随机推荐

  1. js:数据结构笔记4--队列

    队列是一种特殊的列表,数据结构为FIFO: 定义: function Queue() { this.dataStore = []; this.enqueue = enqueue; this.deque ...

  2. objective-c 条件运算符

    条件运算符 val1!=0 ? val1:val2 等价于 val1?val2

  3. OI优化开关

    #pragma comment(linker,"/STACK:10240000,10240000")#pragma GCC optimize ("O2")

  4. CentOS目录结构超详细版

    最近初学Linux 对linux的目录产生了很多疑问,看到这篇文章,让我顿时对目录有了一个清晰的认识!推荐给大家! ------------------------------------------ ...

  5. SecureCrt脚本(二)二级对象之Dialog

    Crt自动化 测试 SecureCrt脚本 JS脚本   1.引言 2.Dialog属性和方法 2.1.属性 2.2.方法 2.2.1.FileOpenDialog 2.2.2.MessageBox ...

  6. 实现自己的Linq to Sql

    之前写过一篇<统一的仓储接口>,为了方便使用不同的仓储.在我们的项目中使用的是EF4.0,但是这个版本的EF有一些性能问题没有解决,又不想升级到EF6,具体EF6有没有解决暂时不清楚.我们 ...

  7. 第十六章 PHP 操作MySQL

    学习要点:1.PHP 连接到MySQL2.增删改查3.其他常用函数 如果你已经具有了使用PHP.SQL 和MySQL 的丰富经验,现在就可以把所有这些技术组合在一起.PHP 与MySQL 之间稳固的集 ...

  8. iOS5中UIViewController的新方法

    iOS5中UIViewController的新方法 前言 在苹果的 WWDC2011 大会视频的<Session 101 - What's New in Cocoa> 和<Sessi ...

  9. JS - 超强大文本动画插件Textillate.js

    http://www.yyyweb.com/demo/textillate/ Textillate.js AsimplepluginforCSS3textanimations.

  10. myeclipse10 将一个java工程合并到web工程

    参考:zhaoshijie http://zhaoshijie.iteye.com/blog/ baidu: http://zhidao.baidu.com/link?url=WXr-EgI0OyUs ...