redis 五种数据结构常用操作命令详解(String,list,set,zset,hash)

本文详细介绍了Redis中的各种核心命令,包括数据结构如字符串、列表、集合和有序集合的操作,如设置/获取值、设置有效期、追加内容、获取长度、添加/删除元素等,以及内存存储模型和一些高级操作,如排序和范围查询。
摘要由CSDN通过智能技术生成

| strlen | 获得对应key存储value的长度 |

| append | 为对应key的value追加内容 |

| getrange 索引0开始 | 截取value的内容(range:范围) |

| setex | 设置一个key存活的有效期(秒)(ex=expire) |

| psetex | 设置一个key存活的有效期(毫秒) |

| setnx | 存在不做任何操作,不存在添加 |

| msetnx原子操作(只要有一个存在不做任何操作) | 可以同时设置多个key,只有有一个存在都不保存 |

| decr | 进行数值类型的-1操作 |

| decrby | 根据提供的数据进行减法操作 |

| Incr | 进行数值类型的+1操作 |

| incrby | 根据提供的数据进行加法操作 |

| Incrbyfloat | 根据提供的数据加入浮点数 |

3、常规命令具体实现

(1)设置/获取一个值

| set | 设置一个key/value |

| — | — |

| get | 根据key获得对应的value |

(2)设置多个值/获取多个值

| mset | 一次设置多个key value |

| — | — |

| mget | 一次获得多个key的value |

(3)获取原始的key值,设置新值

| getset | 获得原始key的值,同时设置新值 |

| — | — |

| rename | 修改键的名字 |

(4)获取key对应的值的长度

| strlen | 获得对应key存储value的长度 |

| — | — |

| | |

(5)给key对应的值的追加值

| append | 为对应key的value追加内容 |

| — | — |

| | |

(6)截取value的内容

| getrange 索引0开始 | 截取value的内容(range:范围) |

| — | — |

| | |

(7)创建并且设置key存活的时间(用来做秒杀之类的)

| setex | 设置一个key存活的有效期(秒)(ex=expire) |

| — | — |

| psetex | 设置一个key存活的有效期(毫秒) |

(8)存在不做任何操作,不存在添加一个或多个值

| setnx | 存在不做任何操作,不存在添加 |

| — | — |

| msetnx原子操作(只要有一个存在不做任何操作) | 可以同时设置多个key,只有有一个存在都不保存 |

(9)对字符串中是数值的减少(如果不是数值,如:"12a"就不能执行改操作)
  • decrease 减少

| decr | 进行数值类型的-1操作 |

| — | — |

| decrby | 根据提供的数据进行减法操作 |

(10)对字符串中是数值(包含小数点)的增加(如果不是数值,如:"12a"就不能执行改操作)
  • Increment:自增

| Incr | 进行数值类型的+1操作 |

| — | — |

| incrby | 根据提供的数据进行加法操作 |

| Incrbyfloat | 根据提供的数据加入浮点数 |

二、List类型

===========================================================================

// list类型 元素有序 且 可以重复

1.内存存储模型

2.常用操作指令

| 命令 | 说明 |

| — | — |

| lpush | 将某个值加入到一个key列表头部 |

| lpushx | 同lpush,但是必须要保证这个key存在 |

| rpush | 将某个值加入到一个key列表末尾 |

| rpushx | 同rpush,但是必须要保证这个key存在 |

| lpop | 返回和移除列表左边的第一个元素 |

| rpop | 返回和移除列表右边的第一个元素 |

| lrange | 获取某一个下标区间内的元素 |

| llen | 获取列表元素个数 |

| lset | 设置某一个指定索引的值(索引必须存在) |

| lindex | 获取某一个指定索引位置的元素 |

| lrem | 删除重复元素 |

| ltrim | 保留列表中特定区间内的元素 |

| linsert | 在某一个元素之前,之后插入新元素 |

3、具体实现

(1)lpush将某个值加入到一个key列表头部

倒序排序,先进去的在后面

lpush users whj yfj zs li ww

(2)lpushx同lpush,但是必须要保证这个key存在

127.0.0.1:6379> lpushx names win7

127.0.0.1:6379> lrange names 0 -1

  1. “win7”

  2. “whj”

  3. “yfj”

  4. “zs”

  5. “li”

  6. “ww”

(3)rpush|将某个值加入到一个key列表末尾

127.0.0.1:6379> lrange users 0 -1

杨福君

zx

dzw

lfk

whx

zxj

yfj

whj

王恒杰

127.0.0.1:6379> rpush users 杨福君

10

127.0.0.1:6379> lrange users 0 -1

杨福君

zx

dzw

lfk

whx

zxj

yfj

whj

王恒杰

杨福君

(4)rpushx同rpush,但是必须要保证这个key存在

127.0.0.1:6379> rpushx names whj

0

127.0.0.1:6379> rpushx users whj

11

127.0.0.1:6379> lrange users 0 -1

杨福君

zx

dzw

lfk

whx

zxj

yfj

whj

王恒杰

杨福君

whj

(5)lpop返回和移除列表左边的第一个元素

127.0.0.1:6379> lrange users 0 -1

zx

dzw

lfk

whx

zxj

yfj

whj

王恒杰

杨福君

whj

127.0.0.1:6379> lpop users

zx

127.0.0.1:6379> lrange users 0 -1

dzw

lfk

whx

zxj

yfj

whj

王恒杰

杨福君

whj

(6)rpop返回和移除列表右边的第一个元素

从右边弹出来四个

127.0.0.1:6379> lrange users 0 -1

dzw

lfk

whx

zxj

yfj

whj

王恒杰

杨福君

whj

127.0.0.1:6379> rpop users

whj

127.0.0.1:6379> rpop users

杨福君

127.0.0.1:6379> rpop users

王恒杰

127.0.0.1:6379> rpop users

whj

127.0.0.1:6379> lrange users 0 -1

dzw

lfk

whx

zxj

yfj

(7)lrange获取某一个下标区间内的元素

lpush users whj yfj dzw zx whx zxj

(8)llen获取列表元素个数

llen users

(9)lset设置某一个指定索引的值(索引必须存在)

lset users 3 lhh

(10)lindex获取某一个指定索引位置的元素

lindex users 3

(11)lrem删除重复元素

rpush users whj

lrem users 2 whj

(12)ltrim 保留列表中特定区间内的元素

ltrim users 0 3

(13)linsert、在某一个元素之前,之后插入新元素

linsert users before whx whj

  • 在某个元素之前添一个数

  • 在某个数之后添加一个数

linsert users after zx lfk

三、Set类型

==========================================================================

key String

vlaue Set集合类型 元素不能存在重复 元素无序 String

特点: Set类型 Set集合 元素无序 不可以重复

1.内存存储模型

2.常用命令

| 命令 | 说明 |

| — | — |

| sadd | 为集合添加元素 |

| smembers | 显示集合中所有元素 无序(member:成员) |

| scard | 返回集合中元素的个数 |

| spop | 随机返回一个元素 并将元素在集合中删除 |

| smove | 从一个集合中向另一个集合移动元素 必须是同一种类型 |

| srem | 从集合中删除一个元素 |

| sismember | 判断一个集合中是否含有这个元素(sis=sister姐妹) |

| srandmember | 随机返回元素(srand:乐趣,根据自己的乐趣返回值) |

| sdiff | 去掉第一个集合中其它集合含有的相同元素 (不会操作原始集合元素) |

| sinter | 求交集(intersection:交集) |

| sunion | 求和集(union:合集) |

(1)sadd:为集合添加元素(无序,自动去重)

sadd names 王恒杰 杨福君周宣君 邓正武 吴洪旭 张茜

(2)smebers:显示集合中所有元素 无序(member:成员)

smembers names

(3)scard:返回集合中元素的个数

scard names

(4)spop:随机返回一个元素 并将元素在集合中删除

spop names

(5)smove:从一个set集合中向另一个set集合移动元素 必须是同一种类型

smove names goodfriend 邓正武

(6)srem:从集合中删除一个元素

srem names 吴洪旭

(7)sismeber:判断一个集合中是否含有这个元素(sis=sister姐妹)

sismember names 张茜

(8)srandmember:随机返回元素(srand:乐趣,根据自己的乐趣返回值)

srandmember names 1

(9)sdiff:去掉第一个集合中其它集合含有的相同元素 (不会操作原始集合元素)

sdiff names goodfriend

(10)sinter:求交集(intersection:交集)

sinter names goodfriend

(11)sunion:求和集(union:合集)

sunion names goodfriend

四、 ZSet类型 SortSet可排序SET

==========================================================================================

ZSET

特点: 1.不可重复 2.可排序的set集合 根据元素分数进行排序

key String

value ZSET

值=分数+值

1.内存模型

2.常用命令

| 命令 | 说明 |

| — | — |

| zadd | 添加一个有序集合元素 |

| zcard | 返回集合的元素个数 |

| zrange 升序 zrevrange 降序 | 返回一个范围内的元素 |

| zrangebyscore | 按照分数查找一个范围内的元素 (实现分页) |

| zrank | 返回排名 |

| zrevrank | 倒序排名 |

| zscore | 显示某一个元素的分数 |

| zrem | 移除某一个元素 |

| zincrby | 给某个特定元素加分 |

(1)zadd:添加一个有序集合元素

zadd schoolreport 30 杨福君 50 邓正武 70 吴洪旭 100 王恒杰

(2)zcard:返回集合的元素个数

zcard schoolreport

(3)zrange 升序 zrevrange 降序:返回一个范围内的元素
  • 返回升序排名zrange
    自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注Java获取)

img

分享

1、算法大厂——字节跳动面试题

2、2000页互联网Java面试题大全

3、高阶必备,算法学习

《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!
n/img_convert/8058f997fa941ef180a051712d8e6131.png)

(3)zrange 升序 zrevrange 降序:返回一个范围内的元素
  • 返回升序排名zrange
    自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。[外链图片转存中…(img-1cgalXft-1713274750832)]

[外链图片转存中…(img-BOynJdFz-1713274750832)]

[外链图片转存中…(img-BfOYSDOn-1713274750833)]

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注Java获取)

img

分享

1、算法大厂——字节跳动面试题

[外链图片转存中…(img-O9vvNsjT-1713274750833)]

2、2000页互联网Java面试题大全

[外链图片转存中…(img-gPkLRNmt-1713274750833)]

3、高阶必备,算法学习

[外链图片转存中…(img-H1C5mdVd-1713274750833)]

《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!

  • 10
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值