Redis数据结构中字符串的探究

1. 总体介绍

  • String属于最常被使用的数据类型,一个键对应着一个值。
  • String具有二进制安全的属性,能够包含诸如图片和序列化对象等各类数据,并且支持序列化操作。
  • 单个值最大可以达到512MB。

image

2. 常见操作

2.1 SET/GET

语法规则:

[ ]代表可选参数

SET key value [NX | XX] [GET] [EX seconds | PX milliseconds | EXAT unix-time-seconds | PXAT unix-time-milliseconds | KEEPTTL]

SET命令存在EXPXNXXX以及KEEPTTL这五个可选参数,其中KEEPTTL是在6.0版本新增的可选参数,其他参数是在2.6.12版本添加的。

  • EX seconds:以秒为单位设置过期时间
  • PX milliseconds:以毫秒为单位设置过期时间
  • EXAT timestamp:设置以秒为单位的UNIX时间戳对应的时间作为过期时间
  • PXAT milliseconds-timestamp:设置以毫秒为单位的UNIX时间戳对应的时间作为过期时间
  • NX:键不存在时设置键值
  • XX:键存在时设置键值
  • KEEPTTL:保留设置前指定键的生存时间
  • GET:返回指定键原本的值,若键不存在则返回nil

SET命令使用EXPXNX参数时,其效果等同于SETEXPSETEXSETNX命令。依据官方文档描述,未来版本中SETEXPSETEXSETNX命令有可能被淘汰。

EXNX可应用于分布式锁。

案例:最为常用的set/get操作

127.0.0.1:6379> set k1 v1
OK
127.0.0.1:6379> get k1
"v1"

案例:NX,键不存在时才能创建,否则无法创建

127.0.0.1:6379> set k1 v1 nx
OK
127.0.0.1:6379> set k1 v1 nx
(nil)

案例:XX,已存在的键才创建,否则无法创建

127.0.0.1:6379> set k1 v1 
OK
127.0.0.1:6379> set k1 v1 xx
OK
127.0.0.1:6379> get k2
(nil)
127.0.0.1:6379> set k2 v2 xx
(nil)

案例:GET,设置新值前先返回旧值

127.0.0.1:6379> set k1 v1
OK
127.0.0.1:6379> set k1 v2 get
"v1"

案例:EX,设置10秒过期

127.0.0.1:6379> set k1 v1 ex 10
OK
127.0.0.1:6379> ttl k1
(integer) 8
127.0.0.1:6379> ttl k1
(integer) 6
127.0.0.1:6379> ttl k1
(integer) 4

set ex是原子操作,与先set key value然后expire key不同,后者不是原子操作

案例:PX,设置9000毫秒过期

127.0.0.1:6379> set k1 v1 px 9000
OK
127.0.0.1:6379> ttl k1
(integer) 7
127.0.0.1:6379> ttl k1
(integer) 5
127.0.0.1:6379> ttl k1
(integer) 4

案例:KEEPTTL

若同一个key设置新值且未追加过期时间,redis会使其立即过期

127.0.0.1:6379> set k1 v1 ex 40
OK
127.0.0.1:6379> ttl k1
(integer) 37
127.0.0.1:6379> set k1 v2
OK
127.0.0.1:6379> ttl k1
(integer) -1

若要续接过期时间,则需要用到KEEPTTL参数,设置新值后,过期时间会被续接

127.0.0.1:6379> set k1 v1 ex 50  
OK
127.0.0.1:6379> ttl k1
(integer) 46
127.0.0.1:6379> set k1 v1 keepttl
OK
127.0.0.1:6379> ttl k1
(integer) 33

2.2 MSET/MGET/MSETNX

案例:MSET同时设置多个值并获取

127.0.0.1:6379> mset k1 v1 k2 v2 k3 v3
OK
127.0.0.1:6379> mget k1 k2 k3
1) "v1"
2) "v2"
3) "v3"

案例 MSETNX,同时设置多个key的值,仅当所有key都不存在时才设置成功,否则全部失败

失败情况,因为k1已存在,k1未成功修改,k2也未存入

127.0.0.1:6379> flushdb
OK
127.0.0.1:6379> set k1 v1
OK
127.0.0.1:6379> msetnx k1 a1 k2 v2
(integer) 0
127.0.0.1:6379> get k1
"v1"
127.0.0.1:6379> get k2
(nil)

成功情况,k1、k2都不存在,全部添加成功

127.0.0.1:6379> flushdb
OK
127.0.0.1:6379> msetnx k1 v1 k2 v2
(integer) 1
127.0.0.1:6379> mget k1 k2
1) "v1"
2) "v2"

2.3 GETRANGE/SETRANGE

GETRANGE,类似Java中的substring(),用于字符串截取,0到-1表示不截取

案例:

127.0.0.1:6379> set k1 abcdefg
OK
127.0.0.1:6379> getrange k1 0 -1
"abcdefg"
127.0.0.1:6379> getrange k1 1 4
"bcde"

SETRANGE,从指定字符位置开始设置新内容

案例:

127.0.0.1:6379> set k1 abcdefg
OK
127.0.0.1:6379> setrange k1 1 xxyy
(integer) 7
127.0.0.1:6379> get k1
"axxyyfg"

2.4 INCR(BY)/DECR(BY)

用于数值的加减操作,值必须是数字才能进行该操作

案例:INCR,每次执行加1

127.0.0.1:6379> set k1 100
OK
127.0.0.1:6379> get k1
"100"
127.0.0.1:6379> incr k1
(integer) 101
127.0.0.1:6379> incr k1
(integer) 102
127.0.0.1:6379> incr k1
(integer) 103
127.0.0.1:6379> incr k1
(integer) 104

案例:INCRBY,修改步长为5

127.0.0.1:6379> set k1 0
OK
127.0.0.1:6379> incrby k1 5
(integer) 5
127.0.0.1:6379> incrby k1 5
(integer) 10
127.0.0.1:6379> incrby k1 5

案例:DECR,递减1,DECRBY同理

127.0.0.1:6379> set k1 100
OK
127.0.0.1:6379> decr k1
(integer) 99
127.0.0.1:6379> decr k1
(integer) 98
127.0.0.1:6379> decr k1
(integer) 97




127.0.0.1:6379> set k1 100
OK
127.0.0.1:6379> decrby k1 5
(integer) 95
127.0.0.1:6379> decrby k1 5
(integer) 90
127.0.0.1:6379> decrby k1 5
(integer) 85

2.5 STRLEN

用于获取字符串长度

语法

strlen key

案例

127.0.0.1:6379> set k1 aaa
OK
127.0.0.1:6379> strlen k1
(integer) 3

2.6 APPEND

用于字符串追加

语法

APPEND key value

案例

127.0.0.1:6379> set k1 aaa
OK
127.0.0.1:6379> append k1 bbb
(integer) 6
127.0.0.1:6379> get k1
"aaabbb"

2.7 GETSET

getset,即先获取值再设置新值,与set key value get命令效果相同

127.0.0.1:6379> set k1 v1
OK
127.0.0.1:6379> getset k1 v2
"v1"
127.0.0.1:6379> get k1
"v2"

3. 总结

字符串是一种基础的数据结构,可应用于分布式锁、点赞数量统计等场景。

文章整理自互联网,只做测试使用。发布者:Lomu,转转请注明出处:https://www.it1024doc.com/12578.html

(0)
LomuLomu
上一篇 2025 年 6 月 19 日
下一篇 2025 年 6 月 19 日

相关推荐

  • spring 事务失效的 12 种场景

    看这个:https://blog.csdn.net/hanjiaqian/article/details/120501741里面有12种失效场景以及如何解决。在 spring 中为了支持编程式事务,专门提供了一个类:TransactionTemplate,在它的 execute 方法中,就实现了事务的功能。 相较于@Transactional注解声明式事务,…

    2025 年 1 月 6 日
    61100
  • IntelliJ IDEA 2024激活破解详细教程(IDEA永久激活码)

    IntelliJ IDEA 是一款广受欢迎的 Java 集成开发环境,以其智能代码助手、代码自动提示和强大的重构功能闻名。然而,对于一些开发者来说,其高昂的订阅费用可能是个不小的负担。本文将介绍一种通过脚本激活 IDEA 的方法,帮助大家免费使用这款强大的开发工具。 一、准备工作 1. 下载并安装最新版本的 IDEA 首先,前往 JetBrains 官网下载…

    未分类 2024 年 6 月 23 日
    2.4K00
  • 实用经验分享idea激活码申领,权威破解教程

    免责声明:下文所提及的 IntelliJ IDEA 破解补丁、激活码均源自互联网公开渠道,仅供学习交流,禁止商业用途。若遇版权争议,请联系删除。条件允许请支持正版! JetBrains 出品的 IntelliJ IDEA 被誉为最强 Java IDE,跨平台支持 Windows、macOS 与 Linux。本篇教程将手把手演示如何利用破解补丁实现“永久激活”…

    IDEA破解教程 2025 年 10 月 19 日
    16100
  • Java操作MySQL数据库:零基础轻松上手

    Java操作MySQL数据库:零基础轻松上手 JDBC的原理 JDBC(Java Database Connectivity)是Java用于连接与操作数据库的API,它能让Java应用程序和各类数据库进行交互,以下是JDBC的基本原理: 驱动程序管理:JDBC借助不同的数据库驱动程序来连接不同类型的数据库。每种数据库都有对应的JDBC驱动程序,负责处理Jav…

    2025 年 7 月 5 日
    35600
  • 实用图文教学:clion激活码申请与最新clion破解教程

    申明:本教程Clion破解补丁、激活码均收集于网络,请勿商用,仅供个人学习使用,如有侵权,请联系作者删除。若条件允许,希望大家购买正版 ! 废话不多说,先上 Clion2025.2.1 版本破解成功的截图,如下图,可以看到已经成功破解到 2099 年辣,舒服的很! 接下来就给大家通过图文的方式分享一下如何破解最新的Clion。 准备工作 注意:如果你之前用过…

    2025 年 12 月 17 日
    9900

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们

400-800-8888

在线咨询: QQ交谈

邮件:admin@example.com

工作时间:周一至周五,9:30-18:30,节假日休息

关注微信