Redis系列-存储篇string主要操作命令

Redis系列-存储篇string主要操作命令

通过上两篇的介绍,我们的redis服务器基本跑起来。db都具有最基本的CRUD功能,我们沿着这个脉络,开始学习redis丰富的数据结构之旅,当然先从最简单且常用的string开始。

1、新增

a)set

语法:set key value

解释:把值value赋给key,如果key不存在,新增;否则,更新

[[email protected] ~]# redis-cli
redis 127.0.0.1:6379> set user.1.name zhangsan #设置user.1.name 为zhangsan
OK
redis 127.0.0.1:6379> set user.name 45      #设置user.1.name 为45
OK

b)setnx

语法:setnx key value

解释:只insert不update,即,仅仅key不存在时,则设置key的值为value,并返回1,否则返回0 ?。setnx 是set if not exists 的缩写

redis 127.0.0.1:6379> setnx user.1.name zhangsan   #user.1.name已经存在,则返回0
(integer) 0
redis 127.0.0.1:6379> setnx user.2.name zhangsan  #user.2.name不存在,则设置
(integer) 1

c)setex

语法: setex key seconds value

解释:设置key的过期时间和值。过期时间seconds单位是秒。设置过期时间和值是原子操作,如果redis仅仅当做缓存,这个很命令很有用。

redis 127.0.0.1:6379> setex user.2.age 2 14  #把user.2.age 的值设14 并且2秒后过期失效
OK
redis 127.0.0.1:6379> get user.2.age  #失效前
"14"
redis 127.0.0.1:6379> get user.2.age #失效后
(nil)

d)mset

语法:mset?key value [key value ...]

解释:同时设置多个key-value

redis 127.0.0.1:6379> mset user.4.name lisi user.4.age 34  #设置user.4.name=lisi,user.4.age=34
OK
redis 127.0.0.1:6379> get user.4.name
"lisi"
redis 127.0.0.1:6379> get user.4.age
"34"

e)msetnx

语法:msetnx?key value [key value ...]

解释:所有key都不存在才执行set操作

redis 127.0.0.1:6379> msetnx user.4.name lisi user.4.age 34  #key 都设置过,无法再次set
(integer) 0
redis 127.0.0.1:6379> msetnx user.4.name lisi user.4.std 3   #key user.4.name 曾设置过,无法再次设置
(integer) 0
redis 127.0.0.1:6379> msetnx user.4.tech lisi user.4.std 3   #key都没有设置过,可以再次设
(integer) 1

2、查询

a)get

语法:get key

解释:获取key所set的值

redis 127.0.0.1:6379> get user.4.name  #获取user.4.name 的值
"lisi"
redis 127.0.0.1:6379> get user.4.age
"34"
redis 127.0.0.1:6379> get user.4.tech
"lisi"
redis 127.0.0.1:6379> get user.4.std
"3"

b)mget

语法: get key [key]

解释:批量获取key的值。程序一次获取多个值,可以减少网络连接损耗。

redis 127.0.0.1:6379> mget user.4.name user.4.age user.4.std #批量获取存在key的值
1) "lisi"   #user.4.name的值
2) "34"     #user.4.age 的值
3) "3"      #user.4.std 的值

redis 127.0.0.1:6379> mget user.4.name user.4.age user.4.std user.4.fri  #key user.4.fri 不存在仍然可以返回
1) "lisi"
2) "34"
3) "3"
4) (nil) #user.4.fri 的值

c)getrange

语法:getrange key star end

解释:获取存储在key中value的字串。字符串的截取有star和end决定,字符串的第一个字符编号是0,第二个是1,一次类推;如果是负数,-1是最后一个字符,-2是倒数第二个字符,一次类推。

redis 127.0.0.1:6379> get user.4.name
"lisi"
redis 127.0.0.1:6379> getrange user.4.name 0 3  # 0 表示开始
"lisi"
redis 127.0.0.1:6379> getrange user.4.name 1 2
"is"
redis 127.0.0.1:6379> getrange user.4.name 1 -2 #-2 表示倒数第二
"is"
redis 127.0.0.1:6379> getrange user.4.name -1 -2  # end 》 start
""
redis 127.0.0.1:6379> getrange user.4.name 1 66  #end 》 值的长度
"isi"

3、修改

a)getset

语法:getset key value

解释:设置key的值,并返回key的旧值。

redis 127.0.0.1:6379> get user.4.name   #存在的key
"lisi"
redis 127.0.0.1:6379> getset user.4.name wangwu  #把存在的user.4.name设置为wagnwu
"lisi"
redis 127.0.0.1:6379> get user.4.name
"wangwu"
redis 127.0.0.1:6379> get user.5.name  #不存在的key
(nil)
redis 127.0.0.1:6379> getset user.5.name lisi
(nil)
redis 127.0.0.1:6379> get user.5.name
"lisi"

?b) append

语法:append key value

解释:key存在,在旧值的后面追加value;key不存在,直接set

redis 127.0.0.1:6379> get user.4.name #存在的key
"wangwu"
redis 127.0.0.1:6379> append user.4.name 01
(integer) 8
redis 127.0.0.1:6379> get user.4.name
"wangwu01"
redis 127.0.0.1:6379> get user.6.name #不能存在的key
(nil)
redis 127.0.0.1:6379> append user.6.name jim
(integer) 3
redis 127.0.0.1:6379> get user.6.name
"jim"

c)setrange

语法:setrange key offset value

解释:用value重写key值的一部分,偏移量由offset指定

redis 127.0.0.1:6379> get user.4.name  #key存在
"wangwu01"
redis 127.0.0.1:6379> setrange user.4.name 0 lisi
(integer) 8
redis 127.0.0.1:6379> get user.4.name
"lisiwu01"
redis 127.0.0.1:6379> setrange user.4.name 9 lisi  # offset 》字符串长度
(integer) 13
redis 127.0.0.1:6379> get user.4.name
"lisiwu01\x00lisi"
redis 127.0.0.1:6379> setrange user.4.name 8 lisi
(integer) 13
redis 127.0.0.1:6379> get user.4.name
"lisiwu01lisii"
redis 127.0.0.1:6379> get user.6.std #key 不存在
(nil)
redis 127.0.0.1:6379> setrange user.6.std 0 3
(integer) 1
redis 127.0.0.1:6379> get user.6.std
"3"

d)incr

语法:incr key

解释:key中如果存储的是数字,则可以通过incr递增key的值,返回递增后的值。如果key不能存在,视为初始值为0

redis 127.0.0.1:6379> get user.7.age #key不存在 ,初始值视为0,
(nil)
redis 127.0.0.1:6379> incr user.7.age
(integer) 1
redis 127.0.0.1:6379> get user.7.age
"1"
redis 127.0.0.1:6379> incr user.7.age
(integer) 2

e)incrby

语法:incrby key increment

解释:用指定的步长增加key存储的数字。如果步长increment是负数,则减

redis 127.0.0.1:6379> get user.7.age
"3"
redis 127.0.0.1:6379> incrby user.7.age 15  #增加15
(integer) 18
redis 127.0.0.1:6379> get user.7.age
"18"
redis 127.0.0.1:6379> incrby user.7.fri 18  #key不能存在,原值视为0
(integer) 18
redis 127.0.0.1:6379> get user.7.fri
"18"
redis 127.0.0.1:6379> incrby  user.7.age -1  #步长为负
(integer) 17
redis 127.0.0.1:6379> get user.7.age
"17"

f)decr

语法:decr key

解释:递减key保存的数字,如果key不存在,初始值视为0

redis 127.0.0.1:6379> get user.7.age
"17"
redis 127.0.0.1:6379> decr user.7.age
(integer) 16
redis 127.0.0.1:6379> decr user.7.num #key 不存在,初始值视为0
(integer) -1
redis 127.0.0.1:6379> decr user.7.num
(integer) -2

g)decrby

语法:decrby key decrement

解释:用指定的步长递减key的值,如果步长decrment是负值,则递增

redis 127.0.0.1:6379> decrby user.7.num 4  #递减
(integer) -6
redis 127.0.0.1:6379> decrby user.7.num -9 #负值,递增
(integer) 3

注意:递增递减系列的函数,只能对保存的是数字的key操作,不能是字符串

4)删除

语法:del key [key]

解释:删除指定的key,返回删除key的个数

redis 127.0.0.1:6379> del user.7.num
(integer) 1
redis 127.0.0.1:6379> get user.7.num
(nil)
redis 127.0.0.1:6379> del user.7.age user.7.fri #删除多个key
(integer) 2
redis 127.0.0.1:6379> mget user.7.age user.7.fri
1) (nil)
2) (nil)

5)其他

语法:strlen key

解释:获取key中所存储值的长度

redis 127.0.0.1:6379> get user.1.name
"45"
redis 127.0.0.1:6379> strlen user.1.name  #user.1.name 长度
(integer) 2
redis 127.0.0.1:6379> strlen user.8.name #key不存在
(integer) 0

通过上面的大量demo,对string的操作基本总结完毕。今天就到这里吧!

更多信息,请参考:http://redis.io/commands#string

原文地址:https://www.cnblogs.com/passzhang/p/12237775.html

时间: 2024-10-09 09:11:04

Redis系列-存储篇string主要操作命令的相关文章

Redis系列-存储篇sorted set主要操作命令

Redis系列-存储篇sorted set主要操作函数小结 redis支持有序集合,即sorted set.sorted set在set的基础上,增加了排序属性,是set的升级版.这里简要谈谈sorted set的常用函数: 1)insert a)zadd 语法:zadd?key score member?[[score member] [score member] ...] 解释:增加一个或多个member[根据score排序]到有序集key中,如果member已经存在,只更新score.返回

Redis系列-存储篇hash主要操作函数小结

hash是一些列key value(field value)的映射表.常常用其存储一些对象实例.相对于把一个对象的各个字段存储为string,存储为hash会占用更少的内存.为什么会更省内存呢?需要搞清楚两个配置(hash-max-zipmap-entries和hash-max-zipmap-value)的含义,配置的详细介绍,我打算放在最后的配置优化环节讲. 1)新增 a)hset 语法:hset key field value 解释:设置hash表key中的field的值.如果hash表不存

Redis系列-存储篇sorted set主要操作函数小结

redis支持有序集合,即sorted set.sorted set在set的基础上,增加了排序属性,是set的升级版.这里简要谈谈sorted set的常用函数: 1)insert a)  zadd 语法:zadd key score member [[score member] [score member] ...] 解释:增加一个或多个member[根据score排序]到有序集key中,如果member已经存在,只更新score.返回增加member个数,不包含已经存在的member [p

Redis系列-存储篇list主要操作函数小结(转)

在总结list之前,先要弄明白几个跟list相关的概念: 列表:一个从左到右的队列,个人理解更类似于一个栈,常规模式下,先进列表的元素,后出. 表头元素:列表最左端第一个元素. 表尾元素:列表最右端的最后一个元素.不包含任何元素的列表成为空列表. 1)新增 a)lpush 语法:lpush key value[value] 解释:把一个或多个元素插入表头.如果是多个value时,按照从左到右的次序插.返回插入元素的个数 [plain] view plaincopy [[email protect

Redis系列-存储篇list主要操作函数小结

在总结list之前,先要弄明白几个跟list相关的概念: 列表:一个从左到右的队列,个人理解更类似于一个栈,常规模式下,先进列表的元素,后出. 表头元素:列表最左端第一个元素. 表尾元素:列表最右端的最后一个元素.不包含任何元素的列表成为空列表. 1)新增 a)lpush 语法:lpush key value[value] 解释:把一个或多个元素插入表头.如果是多个value时,按照从左到右的次序插.返回插入元素的个数 [plain] view plaincopy [[email protect

redis数据类型一之string的操作命令

1.首先在redis官网文档上截取一段做说明: 如图示:这里说redis string 类型是一种能够连接 redis key 的最简单的值的类型,它也是 Memcached 唯一的一种数据类型,所以对于新手来说最易于使用.string数据类型对于一些用户实例是很有帮助的,像 HTML 标签或者是页面.(原谅我做一些英文翻译,打着学英文的口号看遍好莱坞大片.) 2.string数据类型的相关操作命令: i: set/get/del/append/strlen: 分别为 新增/获取/删除/追加/计

Redis系列整理

0.Redis系列-安装部署维护篇 1.Redis系列-远程连接redis并给redis加锁 2.Redis系列-存储篇string主要操作函数小结 3.Redis系列-存储篇list主要操作函数小结 4.Redis系列-存储篇set主要操作函数小结 5.Redis系列-存储篇hash主要操作函数小结 6.使用场景   redis 五种数据类型的使用场景 Nosql 介绍及其使用场景 Redis内存使用优化与存储 HA(High Available), 高可用性群集

Spring Boot 揭秘与实战(二) 数据存储篇 - Redis

文章目录 1. 环境依赖 2. 数据源 2.1. 方案一 使用 Spring Boot 默认配置 2.2. 方案二 手动创建 3. 使用 redisTemplate 操作4. 总结 3.1. 工具类 3.2. 测试类 3.3. 单元测试用例 5. 源代码 本文讲解Spring Boot基础下,如何整合Redis,编写数据访问. 环境依赖 修改 POM 文件,添加 spring-boot-starter-redis 依赖. <dependency> <groupId>org.spri

JDK源码学习--String篇(三) 存储篇

在进一步解读String类时,先了解下内存分配和数据存储的. 数据存储 1.寄存器:最快的存储区,位于处理器的内部.由于寄存器的数量有限,所以寄存器是按需分配. 2.堆栈:位于RAM中,但是通过堆栈指针可以从处理器哪里获得直接支持.堆栈指针向下移动,则分配新的内存:堆栈指针向上移动释放内存. 注:堆栈中存储基本的数据类型和[对象引用],但是Java对象存储在堆中. 3.堆:通用内存池,位于RAM中,用于存放所有的Java对象. 注:堆中存储的 new创建的对象和数组. 4.常量存储:存放常量.