【4858.com】Redis常用命令,Redis数据类型之List类型

By admin in 4858.com on 2019年3月26日

往列表里存放数据先进后出(左进)

Redis数据类型之List类型

List类型(列表类型)

Redis
列表是总结的字符串列表,遵照插入顺序排序。你能够加上三个成分导列表的尾部(左侧)或许尾部(左边)。

它的最底层实际是个链表

序言

思来想去感觉redis中的list没什么好写的,如若单写多少个指令的操作过于单调,所以本篇最终作者会根据redis中list数据类型的与众分裂性质,同时相比成熟的消息队列产品rabbitmq,使用redis达成三个新闻队列。 

为啦让本篇更有魅力,作者再介绍下redis中list的为主个性,以及为何使用redis中list列表类型,为何接纳新闻队列,为何不用rabbitmq而使用redis达成消息队列?呢,到那边截至,若是您是大牛,大腕,大神,岳父!不要听本身吹牛逼啦,Close Page and forget me
! —_— 

  在Redis中,List类型是依据插入顺序排序的字符串链表。和数据结构中的普通链表一样,大家能够在其头顶(left)和尾部(right)添加新的要素。在插入时,要是该键并不设有,Redis将为该键创立三个新的链表。与此相反,假诺链表中有所的因素均被移除,那么该键也将会被从数据库中去除。List中能够涵盖的最大因素数量是4294967295。
     
从要素插入和删除的频率视角来看,假如大家是在链表的双边插入或删除成分,那将会是极度迅猛的操作,即使链表中曾经储存了百万条记下,该操作也得以在常量时间内形成。但是须求证实的是,如若成分插入或删除操作是功用于链表中间,那将会是足够低效的。相信对于有精粹数据结构基础的开发者而言,那或多或少并容易领会。

lpush  names  A  B C D E

List(列表类型)常用命令

先是回应序言中的4大疑问 

一 、redis中的list的主题性情?

List数据结构是链表结构,那意味那无论数据量多大,头尾操作数据依旧相当慢的,list的体积是2的三十三回方减一个要素,即429496729八个要素数量。

贰 、为何采纳redis中的list数据类型?

借助redis内存中操作数据的优势,又提供部分列实用非凡的Api操控数据,用着简便,速度又快,又能达成特有的数量特征排序读写,做时间轴数据,评论列表,音信传递等等,又提供便捷的分页,读写操作。你用不用。

③ 、为啥使用消息队列?

举个简易的例证,功效是那样子的,你要显示页面给用户看,在你呈现页面在此以前有三个很复杂耗费时间的演算要操作,但是那么些操作不影响页面展现的数目,也不作为页面展现的数码。 

方案一:运算完,呈现页面。

方案二:把要计算的数码,抛到持久化的音信队列中,不做耗费时间的运算,直接表现页面。然后用此外四个顺序来对音信队列中的数据单独做运算。 

肯定,方案二是最棒答案,你用不用消息队列。

④ 、为啥不行使成熟的rabbitmq而选用redis完毕的讯息队列? 

Rabbitmq只关注数据的先进先出,没有数量优先级的概念,假使你想给那三个数据来个先处理的特权,那么不好意思,笔者不援救,不过rabbitmq也能够转变着来拍卖,正是创立四个队列用程序路由来落到实处这么些特权功用。那么redis达成的音信队列,是足以灵活掌握控制的,前面做示范。

1、LPUSH key value1 [value2]

 

成立列表

lpush右侧添加/rpush右边添加

lpush从左侧添加

127.0.0.1:6379> lpush list01 1 2 3 4 5
(integer) 5
127.0.0.1:6379> lrange list01 0 -1
1) "5"
2) "4"
3) "3"
4) "2"
5) "1"

rpush从左边添加

127.0.0.1:6379> rpush list02 1 2 3 4 5
(integer) 5
127.0.0.1:6379> lrange list02 0 -1
1) "1"
2) "2"
3) "3"
4) "4"
5) "5"

Redis中有关List列表的命令详解 

壹 、redis中list列表的数额插入命令:lpush,rpush,linsert

127.0.0.1:6379>rpush
mylist 1   —结果为:(integer) 1

127.0.0.1:6379>rpush
mylist 2   —结果为:(integer) 2

127.0.0.1:6379>rpush
mylist 3  
—rpush命令:向mylist列表中,从右边插入3条数据,重返值为近来列表的容积。结果为:(integer)
3

127.0.0.1:6379>lrange
mylist 0 -1  
—lrange命令:查看mylist列表中的数据,0伊始地点,-1了结地方,甘休地点为-1时,表示列表的最后3个地点,即查看全数。结果为:1>
“1”  2> “2”  3> “3”

127.0.0.1:6379>lpush
mylist 0  
—lpush命令:向mylist列表中,从左边插入一条数据为0的多寡

127.0.0.1:6379>lrange
mylist 0 -1   —结果为:1>”0″  2>”1″  3>”2″  4>”3″

127.0.0.1:6379>linsert
mylist after 3 4   —linsert命令,表明式为linsert key before|after
pivot value
;那句发号施令的意思是在key为mylist的列表中查找值为3的多寡,在其后插入一条值为4的数据。

127.0.0.1:6379>lrange
mylist 0 -1   —结果为:1>”0″  2>”1″  3>”2″  4>”3″
 5>”4″

127.0.0.1:6379>linsert
mylist before 0 -1  
—意思是:在key为mylist的列表中查找值为0的多寡,在其前插入一条值为-1的数据。

127.0.0.1:6379>lrange
mylist 0 -1    —结果为:1>”-1″  2>”0″  3>”1″  4>”2″
 5>”3″  6>”4″

127.0.0.1:6379>lisert
mylist after 5 8  
 —结果为:-1,由于mylist列表不设有值为5的数据,所以不进行其余操作,再次回到状态值-1。假设key不设有时,重临错误提醒。

【4858.com】Redis常用命令,Redis数据类型之List类型。127.0.0.1:6379>lrange
mylist 0 -1   —结果为:1>”-1″  2>”0″  3>”1″  4>”2″
 5>”3″  6>”4″

二 、redis中list列表的多寡删除命令:lpop,rpop

127.0.0.1:6379>lpop
mylist  
 —lpop命令:从列表中的右侧移除一条数据,同时输出被去除的多少,那里出口的结果为-1

127.0.0.1:6379>lrange
mylist 0 -1   —结果为:1>”0″  2>”1″  3>”2″  4>”3″
 5>”4″

127.0.0.1:6379>rpop
mylist  
—rpop命令:从列表的左边移除一条数据,同时输出被剔除的多少,那里出口的结果为4

127.0.0.1:6379>lrange
mylist 0 -1   —结果为:1>”0″  2>”1″  3>”2″  4>”3″ 

127.0.0.1:6379>ltrim
mylist 1 3  
—-ltrim命令:保留设定的八个下标区间的值,删除不在其距离的富有值。1为发端保留的下标值,3为完工保留的下标值。

127.0.0.1:6379>lrange
mylist 0 -1   —结果为:1>”1″  2>”2″  3>”3″ 

三 、redis中list列表的数码查看命令:lrange,llen,lindex

127.0.0.1:6379>llen
mylist  
—llen命令:重返列表的长度,那里mylist只剩余4条数据,故输出结果为4

127.0.0.1:6379>lindex
mylist 3  
—lindex命令:获取给定地方的数据,那里坐标为3的数量是”2″,所以结果为2.

四 、redis中list列表数据修改命令:lset

127.0.0.1:6379>lset
mylist 2 zlh  
—lset命令:把下标为2的值设置为zlh,假若下标值超出范围或对一个空list列表进行lset,那么将重临2个荒唐提醒

127.0.0.1:6379>lrange
mylist 0 -1   —结果为: 1>”1″  2>”2″  3>”zlh”

五 、redis中list列表,七个列表A,B,将A列表的尾成分添加到B列表的头成分中,命令:rpoplpush

#那边自身有连个列表A数据为{1,2,3}
,B列表数据为{4,5,6}

127.0.0.1:6379>rpoplpush
A B

127.0.0.1:6379>lrange A  
—结果为:1>”1′ 2>”2″

127.0.0.1:6379>lrange B  
—结果为:1>”3′ 2>”4″ 3>”5″ 4>”6″

陆 、redis中的多少个带阻塞的高级命令:blpop,brpop,brpoplpush

127.0.0.1:6379>blpop A 30
 
—意思是:A列表有值的话,从左边移除一个多少,若是没有值的话,则等待A中插入数据截至,等待时间为30秒,固然时间设置为0表示阻塞时间最棒延伸

127.0.0.1:6379>blpop B30
 
—意思是:A列表有值的话,从左边移除贰个数目,假若没有值的话,则等待A中插入数据截至,等待时间为30秒,假如时间设置为0表示阻塞时间最棒延长

127.0.0.1:6379>brpoplpush
A B 30  
—意思是:将A列表的尾成分添加到B列表的头成分中,假使A列表中有值则插入,假使没值,则等待A中插入数据截至,等待时间为30秒,假设时间设置为0表示阻塞时间最棒延伸

在列表头(左)加上3个或四个值的列表

往列表里存放数据后进先出(右进)

查看List元素

  • lrange key start end start/end超出索引则忽略.
  • lrange key 0 -1 查看list全体成分.
  • lrange key 0 1 查看list 索引为0/1元素.
  • lrange key 0 length+1 查看list 0 – (length-1) 的因素,超出的目录忽略.
  • lrange key 1 3 查看list索引为1-3的元素.

lrange key start end

127.0.0.1:6379> lrange list02 0 -1
1) "1"
2) "2"
3) "3"
4) "4"
5) "5"
127.0.0.1:6379> lrange list02 0 3
1) "1"
2) "2"
3) "3"
4) "4"
127.0.0.1:6379> lrange list02 0 4
1) "1"
2) "2"
3) "3"
4) "4"
5) "5"
127.0.0.1:6379> lrange list02 0 5
1) "1"
2) "2"
3) "3"
4) "4"
5) "5"
127.0.0.1:6379> lrange list02 0 6
1) "1"
2) "2"
3) "3"
4) "4"
5) "5"
127.0.0.1:6379> lrange list02 6 9
(empty list or set)

Redis完毕音讯队列,并自带优先级功效

一 、首先redis中的list是链表结构,具备新闻队列中的先进先出特征。

② 、从地点的多少个高级命令中能够看到,list有多少个自带阻塞功用,时间设置为0,能够说是永不休息的监听进程。

实现:

壹 、说啊以上两点自个儿想你应该有想法啊。

② 、对不起有点晚啦,明天还要上班,还要陪媳妇去吃个麻辣烫,回来睡觉啦,那里一度不难精晓与落到实处啊,如需交流调换学习,进左上角群,对不住呀,88,晚安。

127.0.0.1:6379> lpush mylist a b c
(integer) 3
127.0.0.1:6379> lrange mylist 0 -1
1) "c"
2) "b"
3) "a"

rpush names  G P H K

弹出/取出list元素

lpop key(左边弹出list成分)

127.0.0.1:6379> lpop list01
"5"
127.0.0.1:6379>  lrange list01 0 -1
1) "4"
2) "3"
3) "2"
4) "1"

rpop key(左侧弹出list成分)

127.0.0.1:6379> rpop list02
"5"
127.0.0.1:6379> lrange list02  0 -1
1) "1"
2) "2"
3) "3"
4) "4"

LPUSH 便是在左边插入,插入 a b c 正是先 a -> b a -> c b a 。

 

根据索引获取成分(从上到下)

lindex key index根据索引下标得到成分(从上到下)

127.0.0.1:6379> lindex list01 2
"2"
127.0.0.1:6379> lrange list02 0 -1
1) "1"
2) "2"
3) "3"
4) "4"

2、RPUSH key value1 [value2]

翻看列表里面包车型客车数目:

收获List成分个数

4858.com,llen key获取list成分个数

127.0.0.1:6379> lrange list02 0 -1
1) "1"
2) "2"
3) "3"
4) "4"
127.0.0.1:6379> llen list02
(integer) 4

在列表尾(右)加上三个或多少个值的列表

lrange names 0(从0开始)  -1

删除N个value值

  • lrem key n value 假使没有n个value,有稍许个删除多少个.
  • lrem key n value 从上到下根据顺序删除.

lrem key n

127.0.0.1:6379> lpush list03 1 1 1 2 2 2 3 3 3 4 4 4 4 5 3 4 4 5
(integer) 18
127.0.0.1:6379> llen list03
(integer) 18
127.0.0.1:6379> lrange list03 0 -1
 1) "5"
 2) "4"
 3) "4"
 4) "3"
 5) "5"
 6) "4"
 7) "4"
 8) "4"
 9) "4"
10) "3"
11) "3"
12) "3"
13) "2"
14) "2"
15) "2"
16) "1"
17) "1"
18) "1"
127.0.0.1:6379> lrem list03 4  3
(integer) 4
127.0.0.1:6379> lrange list03 0 -1
 1) "5"
 2) "4"
 3) "4"
 4) "5"
 5) "4"
 6) "4"
 7) "4"
 8) "4"
 9) "2"
10) "2"
11) "2"
12) "1"
13) "1"
14) "1"
127.0.0.1:6379> lrem list03 3 5
(integer) 2
127.0.0.1:6379> lrange list03 0 -1
 1) "4"
 2) "4"
 3) "4"
 4) "4"
 5) "4"
 6) "4"
 7) "2"
 8) "2"
 9) "2"
10) "1"
11) "1"
12) "1"
127.0.0.1:6379> rpush mylist a b c 
(integer) 3
127.0.0.1:6379> lrange mylist 0 -1
1) "a"
2) "b"
3) "c"

切片:

截取list成分并且赋值给list

  • ltrim key start end 把 start end中的成分赋值给key
  • ltrim key start end 是包含 start end 元素
  • ltrim key start end 如若索引超出范围,则自动忽略.

ltrim key start end

127.0.0.1:6379> lpush list04 1 2 3 4 5 6 7 8 9 0
(integer) 10
127.0.0.1:6379> lrange list04 0 -1
 1) "0"
 2) "9"
 3) "8"
 4) "7"
 5) "6"
 6) "5"
 7) "4"
 8) "3"
 9) "2"
10) "1"
127.0.0.1:6379> ltrim list04 3 5
OK
127.0.0.1:6379> lrange list04 0 -1
1) "7"
2) "6"
3) "5"
127.0.0.1:6379> ltrim list04 0 7
OK
127.0.0.1:6379> lrange list04 0 -1
1) "7"
2) "6"
3) "5"

ENCOREPUSH 就是在左边插入,插入 a b c 就是先 a -> a b -> a b c

lrange names  start  end(start end 代表发轫和完工地点)

在list成分前后添加新因素

  • linsert key before/after value new_value
    在value值前后添加new_value
  • 从上到下找到第②个门道相当
  • 找不到则value 那重临-1 不作操作.

linsert key value new_value

127.0.0.1:6379> lpush list05 x i a o m i
(integer) 6
127.0.0.1:6379> lrange list05 0 -1
1) "i"
2) "m"
3) "o"
4) "a"
5) "i"
6) "x"
127.0.0.1:6379> linsert list05 before i 1
(integer) 7
127.0.0.1:6379> linsert list05 after i 2
(integer) 8
127.0.0.1:6379> lrange list05 0 -1
1) "1"
2) "i"
3) "2"
4) "m"
5) "o"
6) "a"
7) "i"
8) "x"
127.0.0.1:6379> linsert list05 after v  100
(integer) -1

3、LPOP key

 

属性特点

  1. 它是一个字符串链表,left、right都得以插入添加;
  2. 假如键不存在,创制新的链表;
  3. 如若键已存在,新增内容;
  4. 比方值全移除,对应的键也就消失了。
  5. 链表的操作无论是头和尾效能都极高,但如若是对中等成分实行操作,功能就很劳苦了。

获得并取出列表中的第三个要素(左边第一个)

插入:

127.0.0.1:6379> rpush mylist a b c 
(integer) 3
127.0.0.1:6379> lrange mylist 0 -1
1) "a"
2) "b"
3) "c"
127.0.0.1:6379> lpop mylist
"a"
127.0.0.1:6379> lpop mylist
"b"
127.0.0.1:6379> lpop mylist
"c"

linsert names  BEFORE/AFTE锐界  D(标杆就是插到哪个地方)  TEST

4、RPOP key

修改:

取出并赢得列表中的最后2个成分(右侧首个)

lset names 3 xiaopang

127.0.0.1:6379> rpush mylist a b c 
(integer) 3
127.0.0.1:6379> lrange mylist 0 -1
1) "a"
2) "b"
3) "c"
127.0.0.1:6379> rpop mylist
"c"
127.0.0.1:6379> rpop mylist
"b"
127.0.0.1:6379> rpop mylist
"a"

删除:

5、LLEN key

lrem name 3 xiaopang

获取列表的尺寸

 

127.0.0.1:6379> lrange mylist 0 -1
1) "a"
2) "b"
3) "c"
127.0.0.1:6379> llen mylist
(integer) 3
127.0.0.1:6379> rpush mylist d
(integer) 4
127.0.0.1:6379> llen mylist
(integer) 4

从列表右边移除:

6、LRANGE key start stop 

lpop names

从叁个列表获取成分,当中start/stop都以下标,并且都可以是负数,比如-1代表尾数首个,-2代表倒数第二个。

 

127.0.0.1:6379> rpush mylist a b c 
(integer) 3
127.0.0.1:6379> lrange mylist 0 -1
1) "a"
2) "b"
3) "c"

除下标1-2其余数据都移除:

7、LTRIM key start stop

LT奇骏IM names 1 2(下标地点)

修理列表到钦命的限制内

 

127.0.0.1:6379> lrange mylist 0 -1
1) "a"
2) "b"
3) "c"
4) "d"
127.0.0.1:6379> ltrim mylist 1 -1
OK
127.0.0.1:6379> lrange mylist 0 -1
1) "b"
2) "c"
3) "d"

names最终二个数量,插入到names2的率先个地点:

这边的 start/stop 也是下标,也得以是负数。

RPOPLPUSH  names  names2

8、LREM key count value

 

据说参数 COUNT 的值,移除列表中与参数 VALUE 相等的成分。

除去列表数据:

COUNT 的值能够是以下三种:

BLPOP  names
4(没有多少就等4秒,有数据就会显得,等待的时候能够继续往里放多少)

  • count > 0 : 从表头初步向表尾搜索,移除与 VALUE 相等的成分,数量为
    COUNT 。
  • count < 0 : 从表尾开始向表头搜索,移除与 VALUE 相等的要素,数量为
    COUNT 的相对值。
  • count = 0 : 移除表中全数与 VALUE 相等的值。

    127.0.0.1:6379> lrange mylist 0 -1
    1) “a”
    2) “b”
    3) “c”
    4) “a”
    5) “a”
    6) “d”
    7) “e”
    127.0.0.1:6379> lrem mylist 2 a
    (integer) 2
    127.0.0.1:6379> lrange mylist 0 -1
    1) “b”
    2) “c”
    3) “a”
    4) “d”
    5) “e”

 

地方的吩咐提醒:在 mylist 列表,从左到右扫描,移除两个与 ‘a’ 相等的值。

 把names里的末段三个多少,放到names2的率先个职位:

6、LINSERT key BEFORE|AFTER pivot value

BRPOPLPUSH names names2 40

在列表中的其余因素之后或事先插入一个要素

127.0.0.1:6379> rpush list1 foo
(integer) 1
127.0.0.1:6379> rpush list1 bar
(integer) 2
127.0.0.1:6379> linsert list1 before bar yes
(integer) 3
127.0.0.1:6379> lrange list1 0 -1
1) "foo"
2) "yes"
3) "bar"

8、LINDEX key index

从一个列表其索引获取相应的要素

127.0.0.1:6379> lrange mylist 0 -1
1) "a"
2) "b"
3) "c"
4) "d"
127.0.0.1:6379> lindex mylist 0
"a"
127.0.0.1:6379> lindex mylist 3
"d"

9、LSET key index value

在列表中的索引设置一个因素的值

127.0.0.1:6379> lrange mylist 0 -1
1) "a"
2) "b"
3) "c"
4) "d"
127.0.0.1:6379> lset mylist 0 aa
OK
127.0.0.1:6379> lrange mylist 0 -1
1) "aa"
2) "b"
3) "c"
4) "d"

 

 

 

====================== 我是罪恶的分割线 ======================

RPOPLPUSH source destination

剔除最终1个要素的列表,将其附加到另3个列表并赶回它

BRPOPLPUSH source destination timeout

从列表中弹出二个值,它推到另3个列表并回到它;或打断,直到有可用

 

BLPOP key1 [key2] timeout

取出并获取列表中的第二个因素,或堵塞,直到有可用

BRPOP key1 [key2] timeout

取出并获得列表中的最终2个因素,或堵塞,直到有可用

 

LPUSHX key value

在头里加上七个值列表,仅当列表中留存

 

发表评论

电子邮件地址不会被公开。 必填项已用*标注

网站地图xml地图
Copyright @ 2010-2019 美高梅手机版4858 版权所有