原文章地址:http://tech.it168.com/a2011/0926/1251/000001251881.shtml
【IT168 专稿】 list是一个链表结构,主要功能是push、pop、获取一个范围的所有值等等,操作中key理解为链表的名字。
系列文章:
Redis的list类型其实就是一个每个子元素都是string类型的双向链表。链表的最大长度是(2的32次方)。我们可以通过push,pop操作从链表的头部或者尾部添加删除元素。这使得list既可以用作栈,也可以用作队列。
有意思的是list的pop操作还有阻塞版本的,当我们[lr]pop一个list对象时,如果list是空,或者不存在,会立即返回nil。但是阻塞 版本的b[lr]pop可以则可以阻塞,当然可以加超时时间,超时后也会返回nil。为什么要阻塞版本的pop呢,主要是为了避免轮询。举个简单的例子如 果我们用list来实现一个工作队列。执行任务的thread可以调用阻塞版本的pop去获取任务这样就可以避免轮询去检查是否有任务存在。当任务来时候 工作线程可以立即返回,也可以避免轮询带来的延迟。说了这么多,接下来看一下实际操作的方法吧:
1、lpush
在key对应list的头部添加字符串元素:
(integer) 1
redis 127.0.0.1:6379> lpush mylist "hello"
(integer) 2
redis 127.0.0.1:6379> lrange mylist 0-1
1) "hello"
2) "world"
redis 127.0.0.1:6379>
在此处我们先插入了一个world,然后在world的头部插入了一个hello。其中lrange是用于取mylist的内容。
2、rpush
在key对应list的尾部添加字符串元素:
(integer) 1
redis 127.0.0.1:6379> rpush mylist2 "world"
(integer) 2
redis 127.0.0.1:6379> lrange mylist2 0-1
1) "hello"
2) "world"
redis 127.0.0.1:6379>
在此处我们先插入了一个hello,然后在hello的尾部插入了一个world。
3、linsert
在key对应list的特定位置之前或之后添加字符串元素:
(integer) 1
redis 127.0.0.1:6379> rpush mylist3 "world"
(integer) 2
redis 127.0.0.1:6379> linsert mylist3 before "world""there"
(integer) 3
redis 127.0.0.1:6379> lrange mylist3 0-1
1) "hello"
2) "there"
3) "world"
redis 127.0.0.1:6379>
在此处我们先插入了一个hello,然后在hello的尾部插入了一个world,然后又在world的前面插入了there。
4、lset
设置list中指定下标的元素值(下标从0开始):
(integer) 1
redis 127.0.0.1:6379> rpush mylist4 "two"
(integer) 2
redis 127.0.0.1:6379> rpush mylist4 "three"
(integer) 3
redis 127.0.0.1:6379> lset mylist4 0"four"
OK
redis 127.0.0.1:6379> lset mylist4 -2"five"
OK
redis 127.0.0.1:6379> lrange mylist4 0-1
1) "four"
2) "five"
3) "three"
redis 127.0.0.1:6379>
在此处我们依次插入了one,two,three,然后将标是0的值设置为four,再将下标是-2的值设置为five。
5、lrem
从key对应list中删除count个和value相同的元素。
count>0时,按从头到尾的顺序删除,具体如下:
(integer) 1
redis 127.0.0.1:6379> rpush mylist5 "hello"
(integer) 2
redis 127.0.0.1:6379> rpush mylist5 "foo"
(integer) 3
redis 127.0.0.1:6379> rpush mylist5 "hello"
(integer) 4
redis 127.0.0.1:6379> lrem mylist5 2"hello"
(integer) 2
redis 127.0.0.1:6379> lrange mylist5 0-1
1) "foo"
2) "hello"
redis 127.0.0.1:6379>
count<0时,按从尾到头的顺序删除,具体如下:
(integer) 1
redis 127.0.0.1:6379> rpush mylist6 "hello"
(integer) 2
redis 127.0.0.1:6379> rpush mylist6 "foo"
(integer) 3
redis 127.0.0.1:6379> rpush mylist6 "hello"
(integer) 4
redis 127.0.0.1:6379> lrem mylist6 -2"hello"
(integer) 2
redis 127.0.0.1:6379> lrange mylist6 0-1
1) "hello"
2) "foo"
redis 127.0.0.1:6379>
count=0时,删除全部,具体如下:
(integer) 1
redis 127.0.0.1:6379> rpush mylist7 "hello"
(integer) 2
redis 127.0.0.1:6379> rpush mylist7 "foo"
(integer) 3
redis 127.0.0.1:6379> rpush mylist7 "hello"
(integer) 4
redis 127.0.0.1:6379> lrem mylist7 0"hello"
(integer) 3
redis 127.0.0.1:6379> lrange mylist7 0-1
1) "foo"
redis 127.0.0.1:6379>
相关推荐
redis数据库:数据存储
Redis专场:Redis Enterprise Alibaba Computing Conference
它没有网络模块,因此您可以自由配置自己的模块,也可以使用默认模块( )例cpp_redis :: client cpp_redis::client client;client.connect();client.set( " hello " , " 42 " );client.get( " hello " , [](cpp_...
Redis-sentinel是Redis的作者antirez完成的,因为Redis实例在各个大公司的应用,每个公司都需要一个Redis集群的管理工具,被迫都自己写管理工具来管理Redis集群,antirez考虑到社区的急迫需要(详情),花了几个星期写...
3.Redis数据类型之List类型
Redis专场:Codis 集群演化与 Redis 异步迁移 阿里巴巴
声明:此文档源自钱文品老师所著《Redis深度历险:核心原理和应用实践》,只供个人学习所用,不得私自用于商业用途Redis 深度历险:核心原理与应用实践 | 钱
Redis系列:深刻理解高性能Redis的本质.doc
redis的比较详细的文档,作用在于应用方面以及他的数据结构类型
Redis命名空间Redis的::命名空间提供了一个接口,您的命名空间的子集密钥空间(例如,具有共同的开始键),并要求宝石。 require 'redis-namespace'# => trueredis_connection = Redis . new# => #<Redis>namespaced...
Redis深度历险:核心原理和应用实践 比较稀缺的紫瑶
RedisBloom:Redis的概率数据结构 RedisBloom模块提供了四个数据结构:可伸缩的Bloom过滤器,布谷鸟过滤器,最小计数草图和top-k 。 这些数据结构以完美的精度为代价,以实现极高的内存效率,因此它们对于大数据和...
Redis实战_Redis实战中文完整版,适合新手入门学习。本文档章节全面,不会有遗落章节。主要包括Redis快速入门、Redis数据类型及操作、Redis常用
SpringDataRedis对Redis的数据类型的常用操作API的使用代码举例
它没有网络模块,因此您可以自由配置自己的模块,也可以使用默认模块( )例cpp_redis :: client cpp_redis::client client;client.connect();client.set( " hello " , " 42 " );client.get( " hello " , [](cpp_...
Redis之五种数据类型的简单增删改查,有详细的操作说明
基于Spark的机器学习资料63、后台服务工具redis:详解redis操作命令.pdf
数据类型详解 以及 redis适用场景场合 数据类型详解 以及 redis适用场景场合
总结《Redis深度历险:核心原理和应用实践》的xmind图