C#Redis列表List

Stella981
• 阅读 773

转载自:https://www.cnblogs.com/5ishare/p/6291034.html

一、前戏

 在Redis中,List类型是按照插入顺序排序的字符串链表。和数据结构中的普通链表一样,我们可以在其头部(left)和尾部(right)添加新的元素。在插入时,如果该键并不存在,Redis将为该键创建一个新的链表。与此相反,如果链表中所有的元素均被移除,那么该键也将会被从数据库中删除。List中可以包含的最大元素数量是4294967295。
      从元素插入和删除的效率视角来看,如果我们是在链表的两头插入或删除元素,这将会是非常高效的操作,即使链表中已经存储了百万条记录,该操作也可以在常量时间内完成。然而需要说明的是,如果元素插入或删除操作是作用于链表中间,那将会是非常低效的。相信对于有良好数据结构基础的开发者而言,这一点并不难理解。

二、理论

命令原型

时间复杂度

命令描述

返回值

LPUSHkey value [value ...] 

O(1)

在指定Key所关联的List Value的头部插入参数中给出的所有Values。如果该Key不存在,该命令将在插入之前创建一个与该Key关联的空链表,之后再将数据从链表的头部插入。如果该键的Value不是链表类型,该命令将返回相关的错误信息。 

插入后链表中元素的数量。

LPUSHX key value 

O(1)  

仅有当参数中指定的Key存在时,该命令才会在其所关联的List Value的头部插入参数中给出的Value,否则将不会有任何操作发生。

插入后链表中元素的数量。 

LRANGE key start stop 

O(S+N)

时间复杂度中的S为start参数表示的偏移量,N表示元素的数量。该命令的参数start和end都是0-based。即0表示链表头部(leftmost)的第一个元素。其中start的值也可以为负值,-1将表示链表中的最后一个元素,即尾部元素,-2表示倒数第二个并以此类推。该命令在获取元素时,start和end位置上的元素也会被取出。如果start的值大于链表中元素的数量,空链表将会被返回。如果end的值大于元素的数量,该命令则获取从start(包括start)开始,链表中剩余的所有元素。

返回指定范围内元素的列表。

LPOPkey 

O(1) 

返回并弹出指定Key关联的链表中的第一个元素,即头部元素,。如果该Key不存,返回nil。

链表头部的元素。

LLENkey

O(1) 

返回指定Key关联的链表中元素的数量,如果该Key不存在,则返回0。如果与该Key关联的Value的类型不是链表,则返回相关的错误信息。

链表中元素的数量。

LREMkey count value 

O(N) 

时间复杂度中N表示链表中元素的数量。在指定Key关联的链表中,删除前count个值等于value的元素。如果count大于0,从头向尾遍历并删除,如果count小于0,则从尾向头遍历并删除。如果count等于0,则删除链表中所有等于value的元素。如果指定的Key不存在,则直接返回0。

返回被删除的元素数量。

LSETkey index value 

O(N) 

时间复杂度中N表示链表中元素的数量。但是设定头部或尾部的元素时,其时间复杂度为O(1)。设定链表中指定位置的值为新值,其中0表示第一个元素,即头部元素,-1表示尾部元素。如果索引值Index超出了链表中元素的数量范围,该命令将返回相关的错误信息。

 

LINDEX key index 

O(N) 

时间复杂度中N表示在找到该元素时需要遍历的元素数量。对于头部或尾部元素,其时间复杂度为O(1)。该命令将返回链表中指定位置(index)的元素,index是0-based,表示头部元素,如果index为-1,表示尾部元素。如果与该Key关联的不是链表,该命令将返回相关的错误信息。

返回请求的元素,如果index超出范围,则返回nil。

LTRIMkey start stop 

O(N) 

N表示被删除的元素数量。该命令将仅保留指定范围内的元素,从而保证链接中的元素数量相对恒定。start和stop参数都是0-based,0表示头部元素。和其他命令一样,start和stop也可以为负值,-1表示尾部元素。如果start大于链表的尾部,或start大于stop,该命令不错报错,而是返回一个空的链表,与此同时该Key也将被删除。如果stop大于元素的数量,则保留从start开始剩余的所有元素。

 

LINSERT key BEFORE|AFTER pivot value 

O(N) 

时间复杂度中N表示在找到该元素pivot之前需要遍历的元素数量。这样意味着如果pivot位于链表的头部或尾部时,该命令的时间复杂度为O(1)。该命令的功能是在pivot元素的前面或后面插入参数中的元素value。如果Key不存在,该命令将不执行任何操作。如果与Key关联的Value类型不是链表,相关的错误信息将被返回。

成功插入后链表中元素的数量,如果没有找到pivot,返回-1,如果key不存在,返回0。

RPUSH key value [value ...] 

O(1) 

在指定Key所关联的List Value的尾部插入参数中给出的所有Values。如果该Key不存在,该命令将在插入之前创建一个与该Key关联的空链表,之后再将数据从链表的尾部插入。如果该键的Value不是链表类型,该命令将返回相关的错误信息。 

插入后链表中元素的数量。 

RPUSHX key value 

O(1) 

仅有当参数中指定的Key存在时,该命令才会在其所关联的List Value的尾部插入参数中给出的Value,否则将不会有任何操作发生。 

插入后链表中元素的数量。 

RPOPkey 

O(1) 

返回并弹出指定Key关联的链表中的最后一个元素,即尾部元素,。如果该Key不存,返回nil。 

链表尾部的元素。 

RPOPLPUSHsource destination 

O(1) 

原子性的从与source键关联的链表尾部弹出一个元素,同时再将弹出的元素插入到与destination键关联的链表的头部。如果source键不存在,该命令将返回nil,同时不再做任何其它的操作了。如果source和destination是同一个键,则相当于原子性的将其关联链表中的尾部元素移到该链表的头部。

返回弹出和插入的元素。

三、实操

C#Redis列表List

127.0.0.1:6379> get mykey
"a"
127.0.0.1:6379> del mykey
(integer) 1
127.0.0.1:6379> get mykey
(nil)
127.0.0.1:6379> lpush mykey a b c
(integer) 3
127.0.0.1:6379> lpush key1 a
(integer) 1
127.0.0.1:6379> del key1
(integer) 1
127.0.0.1:6379> lpushx key1 a
(integer) 0
127.0.0.1:6379> get mye1
(nil)
127.0.0.1:6379> get key1
(nil)
127.0.0.1:6379> lpushx mykey d
(integer) 4
127.0.0.1:6379> lrange mykey -32 4
1) "d"
2) "c"
3) "b"
4) "a"
127.0.0.1:6379> lrange mykey -3 2
1) "c"
2) "b"
127.0.0.1:6379> lrange mykey -3 -1
1) "c"
2) "b"
3) "a"
127.0.0.1:6379> lrange mykey 0 -3
1) "d"
2) "c"
127.0.0.1:6379> lpop mykey
"d"
127.0.0.1:6379> llen mykey
(integer) 3
127.0.0.1:6379> lpush mykey a
(integer) 4
127.0.0.1:6379> lpush mykey b
(integer) 5
127.0.0.1:6379> lrange mykey 0 5
1) "b"
2) "a"
3) "c"
4) "b"
5) "a"
127.0.0.1:6379> lrem mykey 1 a
(integer) 1
127.0.0.1:6379> lrange mykey 0 5
1) "b"
2) "c"
3) "b"
4) "a"
127.0.0.1:6379> lrem mykey 2 b
(integer) 2
127.0.0.1:6379> lrange mykey 0 4
1) "c"
2) "a"
127.0.0.1:6379> lset mykey 0 d
OK
127.0.0.1:6379> lrange mykey 0 2
1) "d"
2) "a"
127.0.0.1:6379> lindex mykey 0
"d"
127.0.0.1:6379> lindex mykey -1
"a"
127.0.0.1:6379> ltrim mykey 0 0
OK
127.0.0.1:6379> lrange mykey 0 2
1) "d"
127.0.0.1:6379> lpush mykey a b c d
(integer) 5
127.0.0.1:6379> lrange mykey 0 4
1) "d"
2) "c"
3) "b"
4) "a"
5) "d"
127.0.0.1:6379> ltrim mykey 0 1
OK
127.0.0.1:6379> lrange mykey 0 4
1) "d"
2) "c"
127.0.0.1:6379> linsert mykey beffor d a
(error) ERR syntax error
127.0.0.1:6379> linsert mykey before d a
(integer) 3
127.0.0.1:6379> lrange mykey 0 3
1) "a"
2) "d"
3) "c"
127.0.0.1:6379> linsert mykey after d a
(integer) 4
127.0.0.1:6379> lrange mykey 0 3
1) "a"
2) "d"
3) "a"
4) "c"
127.0.0.1:6379> rpushx mykey e
(integer) 5
127.0.0.1:6379> lrange myke 0 4
(empty list or set)
127.0.0.1:6379> lrange mykey 0 4
1) "a"
2) "d"
3) "a"
4) "c"
5) "e"
127.0.0.1:6379> del key1
(integer) 0
127.0.0.1:6379> rpushx key1 a
(integer) 0
127.0.0.1:6379> rpush mykey f
(integer) 6
127.0.0.1:6379> rpop mykey
"f"
127.0.0.1:6379> lpush key1 a
(integer) 1
127.0.0.1:6379> lrange key1 0 1
1) "a"
127.0.0.1:6379> lrange mykey 0 5
1) "a"
2) "d"
3) "a"
4) "c"
5) "e"
127.0.0.1:6379> rpoplpush mykey key1
"e"
127.0.0.1:6379> lrange myeky 0 5
(empty list or set)
127.0.0.1:6379> lrange mykey 0 5
1) "a"
2) "d"
3) "a"
4) "c"
127.0.0.1:6379> lrange key1 0 2
1) "e"
2) "a"
127.0.0.1:6379>

C#Redis列表List

点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
待兔 待兔
3个月前
手写Java HashMap源码
HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程22
Jacquelyn38 Jacquelyn38
3年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
Stella981 Stella981
3年前
Opencv中Mat矩阵相乘——点乘、dot、mul运算详解
Opencv中Mat矩阵相乘——点乘、dot、mul运算详解2016年09月02日00:00:36 \牧野(https://www.oschina.net/action/GoToLink?urlhttps%3A%2F%2Fme.csdn.net%2Fdcrmg) 阅读数:59593
Stella981 Stella981
3年前
KVM调整cpu和内存
一.修改kvm虚拟机的配置1、virsheditcentos7找到“memory”和“vcpu”标签,将<namecentos7</name<uuid2220a6d1a36a4fbb8523e078b3dfe795</uuid
Easter79 Easter79
3年前
Twitter的分布式自增ID算法snowflake (Java版)
概述分布式系统中,有一些需要使用全局唯一ID的场景,这种时候为了防止ID冲突可以使用36位的UUID,但是UUID有一些缺点,首先他相对比较长,另外UUID一般是无序的。有些时候我们希望能使用一种简单一些的ID,并且希望ID能够按照时间有序生成。而twitter的snowflake解决了这种需求,最初Twitter把存储系统从MySQL迁移
Stella981 Stella981
3年前
Django中Admin中的一些参数配置
设置在列表中显示的字段,id为django模型默认的主键list_display('id','name','sex','profession','email','qq','phone','status','create_time')设置在列表可编辑字段list_editable
Wesley13 Wesley13
3年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
Python进阶者 Python进阶者
9个月前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这