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

| 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

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

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

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

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

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

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

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

img

最后

码字不易,觉得有帮助的可以帮忙点个赞,让更多有需要的人看到

又是一年求职季,在这里,我为各位准备了一套Java程序员精选高频面试笔试真题,来帮助大家攻下BAT的offer,题目范围从初级的Java基础到高级的分布式架构等等一系列的面试题和答案,用于给大家作为参考

以下是部分内容截图
架构面试专题及架构学习笔记导图.png
《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!

(3)zrange 升序 zrevrange 降序:返回一个范围内的元素

  • 返回升序排名zrange

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

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

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

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

[外链图片转存中…(img-NIpIltCm-1713374658115)]

[外链图片转存中…(img-bqHksNkM-1713374658115)]

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

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

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

img

最后

码字不易,觉得有帮助的可以帮忙点个赞,让更多有需要的人看到

又是一年求职季,在这里,我为各位准备了一套Java程序员精选高频面试笔试真题,来帮助大家攻下BAT的offer,题目范围从初级的Java基础到高级的分布式架构等等一系列的面试题和答案,用于给大家作为参考

以下是部分内容截图
[外链图片转存中…(img-d2BcChlk-1713374658115)]
《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!

  • 19
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值