【redis 】string类型详解

string类型详解

    • 一、string类型的概念
    • 二、string类型的常用指令
      • 2.1 SET
      • 2.2 GET
      • 2.3 MSET
      • 2.4 MGET
      • 2.5 SETNX
      • 2.6 INCR
      • 2.7 INCRBY
      • 2.8 DECR
      • 2.9 DECRBY
      • 2.10 INCRBYFLOAT
      • 2.11 APPEND
      • 2.12 GETRANGE
      • 2.13 SETRANGE
      • 2.14 STRLEN
    • 三、string类型的命令小结
    • 四、string类型的内部编码
    • 五、string类型的典型使用场景

一、string类型的概念

字符串类型是 Redis 最基础的数据类型,关于字符串需要特别注意:

  1. ⾸先 Redis 中所有的键的类型都是字符串类型,⽽且其他⼏种数据结构也都是在字符串类似基础上构建的,例如列表和集合的元素类型是字符串类型,所以字符串类型能为其他 4 种数据结构的学习奠定基础。

在这里插入图片描述

  1. 如上图所⽰,字符串类型的值实际可以是字符串,包含⼀般格式的字符串或者类似 JSON、XML 格式的字符串;数字,可以是整型或者浮点型;甚⾄是⼆进制流数据,例如图⽚、⾳频、视频等。不过⼀个字符串的最⼤值不能超过 512 MB。

二、string类型的常用指令

2.1 SET

将 string 类型的 value 设置到 key 中。如果 key 之前存在,则覆盖,⽆论原来的数据类型是什么。之前关于此 key 的 TTL(键值对的过期时间) 也全部失效。

语法:

SET key value [EX seconds|PX milliseconds|KEEPTTL] [NX|XX]

[ ]内是选填项,其他的是必填项

  • EX seconds:以秒作为单位设置key的过期时间

  • PX milliseconds:以毫秒作为单位设置key的过期时间

  • KEEPTTL:保留设置前指定键的生存时间

  • NX:只在key不存在时才设置,如果设置前key已存在,则不执行

  • XX:只在key存在时才设置,如果设置前key不存在,则不执行

返回值:成功返回ok,失败返回nil

使用方法:

  • 当创建的value值没有空格时:可加引号可不加引号没有影响

  • 当创建的value值有空格时需要加引号,否则会报错

//不存在时创建
127.0.0.1:6379> set key nexit nx
OK
127.0.0.1:6379> get key
"nexit"

//存在不创建
127.0.0.1:6379> set key look nx
(nil)

//存在时创建
127.0.0.1:6379> set key exit xx
OK
127.0.0.1:6379> get key
"exit"

//不存在不创建
127.0.0.1:6379> set key1 look xx
(nil)

//设置key的过期时间为10127.0.0.1:6379> set key second ex 10
OK
127.0.0.1:6379> get key
"second"

//十秒后key被销毁
127.0.0.1:6379> get key
(nil)

2.2 GET

获取 key 对应的 value。如果 key 不存在,返回 nil。如果 value 的数据类型不是 string,会报错。

语法:

GET key

返回值:key 对应的 value,或者 nil 当 key 不存在时

使用方法:

127.0.0.1:6379> set key hello
OK
127.0.0.1:6379> get key
"hello"

//没创建key2,找不到
127.0.0.1:6379> get key2
(nil)

//key3不是string类型,报错
127.0.0.1:6379> hset key3 name lx
(integer) 1
127.0.0.1:6379> get key3
(error) WRONGTYPE Operation against a key holding the wrong kind of value

2.3 MSET

⼀次性设置多个 key 的值

MSET key value [key value ...]

返回值:永远是 OK

使用方法:

127.0.0.1:6379> mset key1 'name' key2 'age'
OK
127.0.0.1:6379> get key1
"name"
127.0.0.1:6379> get key2
"age"

2.4 MGET

⼀次性获取多个 key 的值。如果对应的 key 不存在或者对应的数据类型不是 string,返回 nil

语法:

MGET key [key ...]

返回值:对应 value 的列表

使用方法:

127.0.0.1:6379> mset key1 'hello' key2 'world' key3 'redis'
OK
127.0.0.1:6379> mget key1 key2 key3
1) "hello"
2) "world"
3) "redis"

多次get 和单次mget的区别:

多次get会客户端会和服务器进行多次网络通信

在这里插入图片描述

单次mget客户端和服务器只进行一次网络通信

在这里插入图片描述

使⽤ mget / mset 由于可以有效地减少了⽹络时间,所以性能相较更⾼。假设⽹络耗时 1 毫秒,命令执⾏时间耗时 0.1 毫秒,则执⾏时间如表 所⽰

1000 次 get 和 1 次 mget 对⽐

操作时间
1000 次 get1000 x 1 + 1000 x 0.1 = 1100 毫秒
1 次 mget 1000 个键1 x 1 + 1000 x 0.1 = 101 毫秒

学会使⽤批量操作,可以有效提⾼业务处理效率,但是要注意,每次批量操作所发送的键的数量也不是⽆节制的,否则可能造成单⼀命令执⾏时间过⻓,导致 Redis 阻塞

2.5 SETNX

设置 key-value 但只允许在 key 之前不存在的情况下

语法:

SETNX key value

返回值:1 表⽰设置成功。0 表⽰没有设置

使用方法:

127.0.0.1:6379> setnx key 'hello'
(integer) 1
127.0.0.1:6379> setnx key 'nihao'
(integer) 0
127.0.0.1:6379> get key
"hello"

SET、SET NX 和 SET XX 的执⾏流程如图 :
在这里插入图片描述

2.6 INCR

将 key 对应的 string 表⽰的数字加⼀。如果 key 不存在,则视为 key 对应的 value 是 0。如果 key 对应的 string 不是⼀个整型或者范围超过了 64 位有符号整型,则报错

语法:

INCR key

返回值:integer 类型的加完后的数值

使用方法:

//key 不存在,0 + 1 = 1
127.0.0.1:6379> exists key
(integer) 0
127.0.0.1:6379> incr key
(integer) 1

//整数类型,可以直接加1
127.0.0.1:6379> set key '20'
OK
127.0.0.1:6379> incr key
(integer) 21

//超出了整数类型,报错
127.0.0.1:6379> set key '234293482390480948029348230948'
OK
127.0.0.1:6379> incr key
(error) ERR value is not an integer or out of range

//不是整数类型,报错
127.0.0.1:6379> set key 'not a number'
OK
127.0.0.1:6379> incr key
(error) ERR value is not an integer or out of range

2.7 INCRBY

将 key 对应的 string 表⽰的数字加上对应的值。如果 key 不存在,则视为 key 对应的 value 是 0。如果 key 对应的 string 不是⼀个整型或者范围超过了 64 位有符号整型,则报错

语法:

INCRBY key decrement

返回值:integer 类型的加完后的数值

使用方法:

//key 不存在,0 + 1 = 1
127.0.0.1:6379> exists key
(integer) 0
127.0.0.1:6379> incrby key 3
(integer) 3

//整数类型,可以直接加3
127.0.0.1:6379> set key '10'
OK
127.0.0.1:6379> incrby key 3
(integer) 13

//不能使用非整数类型来加,报错
127.0.0.1:6379> incrby key 'not a number'
(error) ERR value is not an integer or out of range

//所加以后的值超出整数类型,报错
127.0.0.1:6379> incrby key '234293482390480948029348230948'
(error) ERR value is not an integer or out of range

//不能对非整数类型相加
127.0.0.1:6379> set key 'not a number'
OK
127.0.0.1:6379> incrby key 3
(error) ERR value is not an integer or out of range

2.8 DECR

将 key 对应的 string 表⽰的数字减⼀。如果 key 不存在,则视为 key 对应的 value 是 0。如果 key 对应的 string 不是⼀个整型或者范围超过了 64 位有符号整型,则报错

语法:

DECR key

返回值:integer 类型的减完后的数值

使用方法:

//对整数相减
127.0.0.1:6379> exists key
(integer) 0
127.0.0.1:6379> decr key
(integer) -1
127.0.0.1:6379> set key '10'
OK
127.0.0.1:6379> decr key
(integer) 9

//超出整数范围,报错
127.0.0.1:6379> set key '234293482390480948029348230948'
OK
127.0.0.1:6379> decr key
(error) ERR value is not an integer or out of range

//不是整数类型,报错
127.0.0.1:6379> set key 'not a number'
OK
127.0.0.1:6379> decr key
(error) ERR value is not an integer or out of range

2.9 DECRBY

将 key 对应的 string 表⽰的数字减去对应的值。如果 key 不存在,则视为 key 对应的 value 是 0。如果 key 对应的 string 不是⼀个整型或者范围超过了 64 位有符号整型,则报错。

语法:

DECRBY key decrement

返回值:integer 类型的减完后的数值

使用方法:

//对整数类型直接相减
127.0.0.1:6379> exists key
(integer) 0
127.0.0.1:6379> decrby key 3
(integer) -3
127.0.0.1:6379> set key '10'
OK
127.0.0.1:6379> decrby key 3
(integer) 7

//不能使用非整数类型来减
127.0.0.1:6379> decrby key 'not a number'
(error) ERR value is not an integer or out of range

//超出了整数类型,报错
127.0.0.1:6379> set key '234293482390480948029348230948'
OK
127.0.0.1:6379> decrby key
(error) ERR wrong number of arguments for 'decrby' command

//对非整数类型相减,报错
127.0.0.1:6379> set key 'not a number'
OK
127.0.0.1:6379> decrby key 3
(error) ERR value is not an integer or out of range

2.10 INCRBYFLOAT

将 key 对应的 string 表⽰的浮点数加上对应的值。如果对应的值是负数,则视为减去对应的值。如果 key 不存在,则视为 key 对应的 value 是 0。如果 key 对应的不是 string,或者不是⼀个浮点数,则报错。允许采⽤科学计数法表⽰浮点数。

语法:

INCRBYFLOAT key increment

返回值:加/减完后的数值

使用方法:

//正数时,相加
127.0.0.1:6379> set key 10.10
OK
127.0.0.1:6379> incrbyfloat key 0.1
"10.2"

负数时,相减
127.0.0.1:6379> incrbyfloat key -6
"4.2"
127.0.0.1:6379> set key 6.0e3
OK
127.0.0.1:6379> incrbyfloat key 2.0e3
"8000"

很多存储系统和编程语⾔内部使⽤ CAS 机制实现计数功能,会有⼀定的 CPU 开销,但在 Redis 中完全不存在这个问题,因为 Redis 是单线程架构,任何命令到了 Redis 服务端都要顺序执⾏

2.11 APPEND

语法:

APPEND KEY VALUE

返回值:追加完成之后 string 的⻓度

使用方法:

127.0.0.1:6379> get key
(nil)
127.0.0.1:6379> append key 'hello'
(integer) 5
127.0.0.1:6379> get key
"hello"
127.0.0.1:6379> append key 'world'
(integer) 10
127.0.0.1:6379> get key
"helloworld"

2.12 GETRANGE

返回 key 对应的 string 的⼦串,由 start 和 end 确定(左闭右闭)。可以使⽤负数表⽰倒数。-1 代表倒数第⼀个字符,-2 代表倒数第⼆个,其他的与此类似。超过范围的偏移量会根据 string 的⻓度调整成正确的值。

语法:

GETRANGE key start end

返回值:string 类型的⼦串

使用方法:

127.0.0.1:6379> set key 'this is a string'
OK
127.0.0.1:6379> getrange key 0 3
"this"
127.0.0.1:6379> getrange key -3 -1
"ing"
127.0.0.1:6379> getrange key 0 -1
"this is a string"

2.13 SETRANGE

覆盖字符串的⼀部分,从指定的偏移开始

语法:

SETRANGE key offset value

返回值:替换后的 string 的⻓度

使用方法:

127.0.0.1:6379> set key 'hello world'
OK
127.0.0.1:6379> setrange key 6 'redis'
(integer) 11
127.0.0.1:6379> get key
"hello redis"

//如果key不存在,从零位置开始替换不会报错
127.0.0.1:6379> setrange key1 0 'hello'
(integer) 5
127.0.0.1:6379> get key1
"hello"

//key不存在,从0以后的位置开始会报错
127.0.0.1:6379> set range key2 3 'hello'
(error) ERR syntax error

2.14 STRLEN

获取 key 对应的 string 的⻓度。当 key 存放的类似不是 string 时,报错

语法:

STRLEN key

返回值:string 的⻓度。或者当 key 不存在时,返回 0

使用方法:

127.0.0.1:6379> set key 'hello world'
OK
127.0.0.1:6379> strlen key
(integer) 11
127.0.0.1:6379> strlen nonexisting
(integer) 0

三、string类型的命令小结

命令执⾏效果时间复杂度
set key value [key value…]设置 key 的值是 valueO(k), k 是键个数
get key获取 key 的值O(1)
del key [key …]删除指定的 keyO(k), k 是键个数
mset key value [key value …]批量设置指定的 key 和 valueO(k), k 是键个数
mget key [key …]批量获取 key 的值O(k), k 是键个数
incr key指定的 key 的值 +1O(1)
decr key指定的 key 的值 -1O(1)
incrby key n指定的 key 的值 +nO(1)
decrby key n指定的 key 的值 -nO(1)
incrbyfloat key n指定的 key 的值 +nO(1)
append key value指定的 key 的值追加 valueO(1)
strlen key获取指定 key 的值的⻓度O(1)
setrange key offset value覆盖指定 key 的从 offset 开始的部分值O(n),n 是字符串⻓度, 通常视为 O(1)
getrange key start end获取指定 key 的从 start 到 end 的部分值O(n),n 是字符串⻓度, 通常视为 O(1)

四、string类型的内部编码

字符串类型的内部编码有 3 种:

  1. int:8 个字节的⻓整型。

  2. embstr:⼩于等于 39 个字节的字符串

  3. raw:⼤于 39 个字节的字符串

Redis 会根据当前值的类型和⻓度动态决定使⽤哪种内部编码实现

整型类型⽰例如下:

127.0.0.1:6379> set key 6379
OK
127.0.0.1:6379> object encoding key
"int"

短字符串⽰例如下:

//⼩于等于 39 个字节的字符串
127.0.0.1:6379> set key "hello"
OK
127.0.0.1:6379> object encoding key
"embstr"

⻓字符串⽰例如下:

//⼤于 39 个字节的字符串
127.0.0.1:6379> set key "one string greater than 39 bytes ........"
OK
127.0.0.1:6379> object encoding key
"raw"

五、string类型的典型使用场景

缓存(Cache)功能

  • 下图 是⽐较典型的缓存使⽤场景,其中 Redis 作为缓冲层,MySQL 作为存储层,绝⼤部分请求的数据都是从 Redis 中获取。由于 Redis 具有⽀撑⾼并发的特性,所以缓存通常能起到加速读写和降低后端压⼒的作⽤

计数(Counter)功能

  • 许多应⽤都会使⽤ Redis 作为计数的基础⼯具,它可以实现快速计数、查询缓存的功能,同时数据可以异步处理或者落地到其他数据源。例如视频⽹站的视频播放次数可以使⽤ Redis 来完成:⽤⼾每播放⼀次视频,相应的视频播放数就会⾃增 1

共享会话(Session)

  • ⼀个分布式 Web 服务将⽤⼾的 Session 信息(例如⽤⼾登录信息)保存在各⾃的服务器中,但这样会造成⼀个问题:出于负载均衡的考虑,分布式服务会将⽤⼾的访问请求均衡到不同的服务器上,并且通常⽆法保证⽤⼾每次请求都会被均衡到同⼀台服务器上,这样当⽤⼾刷新⼀次访问是可能会发现需要重新登录,这个问题是⽤⼾⽆法容忍的

⼿机验证码

  • 很多应⽤出于安全考虑,会在每次进⾏登录时,让⽤⼾输⼊⼿机号并且配合给⼿机发送验证码,然后让⽤⼾再次输⼊收到的验证码并进⾏验证,从⽽确定是否是⽤⼾本⼈。为了短信接⼝不会频繁访问,会限制⽤⼾每分钟获取验证码的频率,例如⼀分钟不能超过 5 次

以上介绍了使⽤ Redis 的字符串数据类型可以使⽤的⼏个场景,但其适⽤场景远不⽌于此 。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/925256.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

R-Meta分析

原文:R-Meta分析https://mp.weixin.qq.com/s/9ziVzSNRsgUbV9hTtXz5_g?token340211611&langzh_CN 一:AIMeta分析检索 1、AI大模型助力Meta分析的选题与文献检索 1)什么是Meta分析 2)Meta分析的选题策略 3)精确检索策略,如何检索全、检索…

如何在Spring项目中连接redis客户端并使用redis

如何连接redis客户端 我们知道我们在自己的云服务中下载好的redis的端口号呢,是6379,在云服务器中是受到防火墙保护的。但是我们可以通过ssh的隧道来映射到我们的redis客户端。 点击自己云服务器的属性,在这里面添加。 如图: 上…

微信小游戏/抖音小游戏SDK接入踩坑记录

文章目录 前言问题记录1、用是否存在 wx 这个 API 来判断是微小平台还是抖小平台不生效2、微小支付的参数如何获取?3、iOS 平台不支持虚拟支付怎么办?微小 iOS 端支付时序图:抖小 iOS 端支付:4、展示广告时多次回调 onClose5、在使用单例时 this 引起的 bug6、使用 fetch 或…

wkhtmltopdf的安装与使用

本文来记录下wkhtmltopdf的安装与使用 文章目录 概述下载路径安装配置wkhtmltopdf 参数详解代码实现本文小结 概述 将html转为pdf的组件有很多,但是还没有哪一款能达到这个效果,其只要原因是wkhtmltopdf使用webkit网页渲染引擎开发的用来将 html转成 pdf…

消息队列详解:从基础到高级应用

本文主旨 撰写这篇文章的目的在于向读者提供一个全面理解消息队列概念及其在实际应用中重要性的指南。通过从RocketMQ的基础组件如生产者、消费者、主题等的介绍到更高级的概念,比如集群消费与广播消费的区别、顺序消息的重要性等,我们希望能够帮助开发…

【MySQL篇】持久化和非持久化统计信息的深度剖析(第一篇,总共六篇)

💫《博主介绍》:✨又是一天没白过,我是奈斯,DBA一名✨ 💫《擅长领域》:✌️擅长Oracle、MySQL、SQLserver、阿里云AnalyticDB for MySQL(分布式数据仓库)、Linux,也在扩展大数据方向的知识面✌️…

redis大key和热key

redis中大key、热key 什么是大key大key可能产生的原因大key可能会造成什么影响如何检测大key如何优化删除大key时可能的问题删除大key的策略 热key热key可能导致的问题解决热key的方法 什么是大key 大key通常是指占用内存空间过大或包含大量元素的键值对。 数据量大&#xff…

C++语法·叭

阁下何不乘风起,扶摇直上九万里。 qi fei 目录 内存管理 分区介绍 1.栈区: 2.内存映射段: 3.堆: 4.数据段: 5.代码段: 补充: C内存管理(简略回忆) C内存…

elasticsearch单节点模式部署

原文地址:elasticsearch单节点模式部署 – 无敌牛 欢迎参观我的个人博客:无敌牛 – 技术/著作/典籍/分享等 第一步:下载 官方下载地址:Download Elasticsearch | Elastic,可以 wget 直接下载。 命令:wg…

【北京迅为】iTOP-4412全能版使用手册-第二十章 搭建和测试NFS服务器

iTOP-4412全能版采用四核Cortex-A9,主频为1.4GHz-1.6GHz,配备S5M8767 电源管理,集成USB HUB,选用高品质板对板连接器稳定可靠,大厂生产,做工精良。接口一应俱全,开发更简单,搭载全网通4G、支持WIFI、蓝牙、…

Spring AOP相关知识详解

难 文章目录 1.AOP介绍1.1 面向切面编程 - Aspect Oriented Programming (AOP)1.2 优点 2.AOP的概念2.1 连接点、切入点、通知、切面:2.2 注解2.2.1 通知类型2.2.1.1 通知的优先级排序 2.2.2 其他重要注解2.2.3 示例代码(四种通知) 3.Spring …

外包干了3年,技术退步明显...

先说情况,大专毕业,18年通过校招进入湖南某软件公司,干了接近6年的功能测试,今年年初,感觉自己不能够在这样下去了,长时间呆在一个舒适的环境会让一个人堕落! 而我已经在一个企业干了四年的功能…

【阅读记录-章节4】Build a Large Language Model (From Scratch)

文章目录 4. Implementing a GPT model from scratch to generate text4.1 Coding an LLM architecture4.1.1 配置小型 GPT-2 模型4.1.2 DummyGPTModel代码示例4.1.3 准备输入数据并初始化 GPT 模型4.1.4 初始化并运行 GPT 模型 4.2 Normalizing activations with layer normal…

C7.【C++ Cont】范围for的使用和auto关键字

目录 1.知识回顾 2.范围for 格式 使用 运行结果 运行过程 范围for的本意 作用 注意 3.底层分析范围for的执行过程 反汇编代码 分析 4.auto关键字 格式 基本用法 在范围for中使用auto 1.知识回顾 for循环的使用参见25.【C语言】循环结构之for文章 2.范围for C…

【数据结构】双向链表、单向循环链表、双向循环链表、栈、链栈

目录 一、双向链表 定义类和封装函数以及测试样例如下: 注意事项: 二、循环链表 单循环列表的类和函数封装如下: 注意事项: 三、双向循环链表 结点类和双循环链表的定义部分 函数封装之判空和尾插 双循环链表遍历 双循…

ModuleNotFoundError: No module named ‘_ssl‘ centos中的Python报错

1、检查系统有没有openssl,有的话,就是python安装时没有指定openssl openssl version,有输出版本号就有,没有的话,需要手动安装 下载地址 参见https://www.openssl.org/,包括以下版本: https:/…

C语言:树

在C语言中,树(Tree)是一种常见的数据结构,用于表示分层关系或层次结构的数据集合。树在计算机科学中广泛应用,包括但不限于文件系统、解析表达式、数据压缩、决策树等。 1. 基本概念 节点(Node&#xff0…

python写的服务,用docker制作镜像并且打包

步骤1 简单写一个python服务脚本app.py,通过http访问一个端口,收到helloworld from flask import Flask, request app Flask(__name__) app.route(/, methods[GET]) # 确保包括GET方法 def hello_world(): return Hello, World! if __name__ __main…

NSSCTF web刷题

1 虽然找到了flag,但是我要怎么去改他的代码,让他直接输出flag呢? (好像是要得到他的json代码,这题不让看) 2 wllm应该就是他的密码,进入许可了 意思是服务器可以执行通过POST的请求方式传入参数为wllm的命令,那这就是典型的命令执行,当然&#xff0c…

(0基础保姆教程)-JavaEE开课啦!--11课程(初识Spring MVC + Vue2.0 + Mybatis)-实验9

一、什么是Spring MVC? Spring MVC 是一个基于 Java 的 Web 框架,遵循 MVC 设计模式,用于构建企业级应用程序。它通过控制器(Controller)处理用户请求,模型(Model)处理业务逻辑,视图(View)展示数据,实现了请…