Redis 数据类型-List

lpush/rpush/lrange

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"
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"
127.0.0.1:6379> 

lpush 为先进后出,lpush相当于从左侧开始入栈

rpush 为先进先出,rpush相当于从右侧开始入栈

lrange list01 0 -1  其中范围(0 -1)为取所有数据,从栈顶开始取数据

LPOP/RPOP 相当于弹栈,将数据弹出站

127.0.0.1:6379> LRANGE list01 0 -1
1) "5"
2) "4"
3) "3"
127.0.0.1:6379> LPOP list01 弹出栈顶数据
"5"
127.0.0.1:6379> RPOP list01 弹出栈底数据
"3"
127.0.0.1:6379> LRANGE LIST01 0 -1
(empty list or set)
127.0.0.1:6379> LRANGE list01 0 -1
1) "4"
127.0.0.1:6379>

LINDEX 按照索引下标获得元素(从上到下)

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

LLEN 获取长度

127.0.0.1:6379> LLEN list01
(integer) 3
127.0.0.1:6379>

LREM KEY 删除N个value

127.0.0.1:6379> RPUSH list03 1 1 1 2 2 2 3 3 3 4 4 4 5
(integer) 13
127.0.0.1:6379> LREM list03 2 3(删除2个3)
(integer) 2
127.0.0.1:6379> LRANGE list03 0 -1
1) "1"
2) "1"
3) "1"
4) "2"
5) "2"
6) "2"
7) "3"
8) "4"
9) "4"
10) "4"
11) "5"
127.0.0.1:6379>

ltrim key 开始index 结束index, 截取指定范围的值再赋值给key

127.0.0.1:6379> LPUSH list01 1 2 3 4 5 6 7 8
(integer) 8
127.0.0.1:6379> LRANGE list01 0 -1
1) "8"
2) "7"
3) "6"
4) "5"
5) "4"
6) "3"
7) "2"
8) "1"
127.0.0.1:6379> LTRIM list01 3 5 (截取下标为3-5的数值,下表从0开始,再赋值给list01)
OK
127.0.0.1:6379> LRANGE list01 0 -1
1) "5"
2) "4"
3) "3"
127.0.0.1:6379>

RPOPLPUSH 源列表 目的列表 (将一个数据弹出,使用rpop弹出的底部数据,lpush放入另一个中)

127.0.0.1:6379> lrange list02 0 -1
1) "2"
2) "3"
3) "4"
127.0.0.1:6379> lrange list01 0 -1
1) "8"
2) "7"
3) "6"
4) "5"
5) "4"
6) "3"
7) "2"
8) "1"
127.0.0.1:6379> RPOPLPUSH list01 list02
"1"
127.0.0.1:6379> LRANGE list02 0 -1
1) "1"
2) "2"
3) "3"
4) "4"
127.0.0.1:6379>

lset key index value 对index位置的进行赋值value

127.0.0.1:6379> LRANGE list01 0 -1
1) "8"
2) "7"
3) "6"
4) "5"
5) "4"
6) "3"
127.0.0.1:6379> LSET list01 1 x
OK
127.0.0.1:6379> LRANGE list01 0 -1
1) "8"
2) "x"
3) "6"
4) "5"
5) "4"
6) "3"
127.0.0.1:6379>

linsert key before/after 值1 值2(在指定值 前/后 插入一个值)

127.0.0.1:6379> LRANGE list01 0 -1
1) "8"
2) "x"
3) "6"
4) "5"
5) "4"
6) "3"
127.0.0.1:6379> LINSERT list01 before x java
(integer) 7
127.0.0.1:6379> LRANGE list01 0 -1
1) "8"
2) "java"
3) "x"
4) "6"
5) "5"
6) "4"
7) "3"
127.0.0.1:6379> LINSERT list01 before x x
(integer) 8
127.0.0.1:6379> LRANGE list01 0 -1
1) "8"
2) "java"
3) "x"
4) "x"
5) "6"
6) "5"
7) "4"
8) "3"
127.0.0.1:6379> LINSERT list01 before x java(如果指定值有重复,则找到的是第一个)
(integer) 9
127.0.0.1:6379> LRANGE list01 0 -1
1) "8"
2) "java"
3) "java"
4) "x"
5) "x"
6) "6"
7) "5"
8) "4"
9) "3"
127.0.0.1:6379>

性能总结:

它是一个字符串链表,left、right都可以插入添加;

如果键不存在,创建新的链表;

如果键已存在,新增内容;

如果值全部移除,对应的键也就消失了。

链表的操作无论是头部和尾部效率都极高,但假如是对中间元素进行操作,效率就很惨淡了。

时间: 2024-08-29 00:54:22

Redis 数据类型-List的相关文章

redis数据类型

Redis 数据类型 Redis支持五种数据类型:string(字符串),hash(哈希),list(列表),set(集合)及zset(sorted set:有序集合). String(字符串) string是redis最基本的类型,一个key对应一个value. string类型是二进制安全的.意思是redis的string可以包含任何数据.比如jpg图片或者序列化的对象 . string类型是Redis最基本的数据类型,一个键最大能存储512MB. 实例: 在以上实例中我们使用了 Redis

Redis数据类型之字典

Redis数据类型之字典 标签(空格分隔): redis redis的字典 字典又称符号表(symbol table),关联数组(associative array),或者映射(map).是用于保存键值对的一种抽象数据结构. 字典的key是唯一的,对键值对的操作基本都是基于key来操作的.redis中的数据库底层是使用字典来实现的,对于数据库的增删改查都是基于字典来实现的.redis的哈希键也是基于字典来实现的. 具体的实现是在src下的dict.h和dict.c文件 字典的数据结构 哈希表结点

Redis数据类型之链表

Redis数据类型之链表 链表的实现 redis的列表的底层实现就是一个双链表,源码在src下的adlist.h和adlist.c 链表的结点数据结构 /* * 双端链表节点 */ typedef struct listNode { // 前置节点 struct listNode *prev; // 后置节点 struct listNode *next; // 节点的值 void *value; } listNode; 链表数据结构 /* * 双端链表结构 */ typedef struct l

Redis数据类型简介

Redis 数据类型 Redis支持五种数据类型:string(字符串),hash(哈希),list(列表),set(集合)及zset(sorted set:有序集合). String(字符串) string是redis最基本的类型,你可以理解成与Memcached一模一样的类型,一个key对应一个value. string类型是二进制安全的.意思是redis的string可以包含任何数据.比如jpg图片或者序列化的对象 . string类型是Redis最基本的数据类型,一个键最大能存储512M

redis数据类型及使用场景

Redis数据类型  String: Strings 数据结构是简单的key-value类型,value其实不仅是String,也可以是数字. 常用命令:  set,get,decr,incr,mget 等. 应用场景:String是最常用的一种数据类型,普通的key/ value 存储都可以归为此类.即可以完全实现目前 Memcached 的功能,并且效率更高.还可以享受Redis的定时持久化,操作日志及 Replication等功能.除了提供与 Memcached 一样的get.set.in

Lua 数据类型和 Redis 数据类型之间转换

当 Lua 通过 call() 或 pcall() 函数执行 Redis 命令的时候,命令的返回值会被转换成 Lua 数据结构. 同样地,当 Lua 脚本在 Redis 内置的解释器里运行时,Lua 脚本的返回值也会被转换成 Redis 协议(protocol),然后由 EVAL 将值返回给客户端. 数据类型之间的转换遵循这样一个设计原则:如果将一个 Redis 值转换成 Lua 值,之后再将转换所得的 Lua 值转换回 Redis 值,那么这个转换所得的 Redis 值应该和最初时的 Redi

Redis 学习笔记(二) Redis 数据类型

Redis 数据类型 Redis 支持五种数据类型:string(字符串).list(列表).hash(哈希).set(集合)和 zset(有序集合),接下来我们讲解分别讲解一下这五种类型的的使用. String(字符串) string 类型是 redis 最基本的类型,很多人说如果去除本地持久化,只使用 string 的话,那 redis 就是一个 memcached.string 类型,一个 key 对应一个 value,一个 value 最大能存储512MB的数据.string 类型是二进

Redis-cluster集群【第一篇】:redis安装及redis数据类型

Redis介绍: 一.介绍 redis 是一个开源的.使用C语言编写的.支持网络交互的.可以基于内存也可以持久化的Key-Value数据库. redis的源码非常简单,只要有时间看看谭浩强的C语言,在去看redis的源码能看懂50-60%. redis目前最大的集群应该是新浪的应该. redis目前是vmvaer来支持的,很多的开源软件都需要某些组织来支持的.如果一个开源软件没有金钱来支持的话很难走的持久 二.Redis和Memcache对比 持久化:以电商举例,session用memcache

python在运维项目中用到的redis数据类型

先感叹下,学东西一定要活学活用!   我用redis也有几年的历史了,今个才想到把集合可以当python list用.  最近做了几个项目都掺杂了redis, 遇到了一些个问题和开发中提高性能的方法,这都分享出来,共同学习. 下面先简单讲讲Redis集合的数据类型. sadd,创建一个集合,并添加数据. [[email protected] ~]# redis-cli redis 127.0.0.1:6379>  redis 127.0.0.1:6379>  redis 127.0.0.1:6

Redis数据类型之字符串

Redis数据类型之字符串 redis的字符串 redis的字符串不是C语言原生的字符串,而是自己构建的称为简单动态字符串(simple dynamic string),简称 SDS,和C语言原生的字符串相似,使用'\0'作为结尾. 除了打印日志之外,我们操作字符串基本是在使用SDS SDS的在redis的主要功能 1. 保存数据库的字符串值 2. 用作缓冲区buffer SDS在redis的定义 在源码包下面的src目录下的sds.h 和sds.c typedef char *sds; /**