#设置值

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

SET命令加上选项已经可以完全取代SETNXSETEXPSETEX的功能,所以在将来的版本中,redis可能会不推荐使用并且最终抛弃这几个命令。

所以我依次介绍下set的不同模式,实例中GET获取String值不再介绍。

#第一种常规

127.0.0.1:6379> set Current 2018-03-04
OK
127.0.0.1:6379> get Current
"2018-03-04"

#设置有生存时间的key

#将CurrentHaveTimeOut设置为120s的生成时间

127.0.0.1:6379> set CurrentHaveTimeOut test Ex 120
OK

#查看时间,还有108s会被删除

127.0.0.1:6379> ttl CurrentHaveTimeOut
(integer) 108

#过了2分钟再次获取

127.0.0.1:6379> get CurrentHaveTimeOut
(nil)

#设置为仅当key不存在的时候才能设置

127.0.0.1:6379> set CurrentHaveNx test NX
OK 

#再次重复设置

127.0.0.1:6379> set CurrentHaveNx test NX
(nil)

#和NX相反的是XX,仅有key存在的时候才能修改

#值不存在的时候设置失败

127.0.0.1:6379> set CurrentHaveXx test XX
(nil)

#设置值

127.0.0.1:6379> set CurrentHaveXx test1
OK

#进行XX模式修改重设成功

127.0.0.1:6379> set CurrentHaveXx test XX
OK

127.0.0.1:6379> get CurrentHaveXx
"test"

#tips:NX模式可用来制作redis锁。依赖的就是用NXSET来判断锁是否存在

#给String追加值

APPEND key value

如果 key 已经存在,并且值为字符串,那么这个命令会把 value 追加到原来值(value)的结尾。 如果 key 不存在,那么它将首先创建一个空字符串的key,再执行追加操作

127.0.0.1:6379> EXISTS key
(integer) 0
127.0.0.1:6379> APPEND key gavin
(integer) 5
127.0.0.1:6379> get key
"gavin"
127.0.0.1:6379> APPEND key jun
(integer) 8
127.0.0.1:6379> get key
"gavinjun"

#指定位置字符串替换

SETRANGE key offset value

这个命令的作用是覆盖key对应的string的一部分,从指定的offset处开始,覆盖value的长度。如果offset比当前key对应string还要长,那这个string后面就补0以达到offset。不存在的keys被认为是空字符串,所以这个命令可以确保key有一个足够大的字符串,能在offset处设置value。

#情况一正常情况,offset不超过长度

127.0.0.1:6379> set key1 "hello world!"
OK
127.0.0.1:6379> get key1
"hello world!"
127.0.0.1:6379> SETRANGE key1 6 redis
(integer) 12
127.0.0.1:6379> get key1
"hello redis!"

#情况二 String不存在,和存在但是offset大于字符串长度

#不存在的情况,会进行补0操作

127.0.0.1:6379> SETRANGE key2 3 test
(integer) 7
127.0.0.1:6379> get key2
"\x00\x00\x00test"

#offset大于字符串长度,情况和上面类似,都是前补0

127.0.0.1:6379> set key3 t
OK
127.0.0.1:6379> get key3
"t"
127.0.0.1:6379> SETRANGE key3 3 go
(integer) 5
127.0.0.1:6379> get key3
"t\x00\x00go"

#获取key的字符串长度

STRLEN key

返回key的string类型value的长度。如果key对应的非string类型,就返回错误。

127.0.0.1:6379> STRLEN key3
(integer) 5

#举例一种非string类型的情况

127.0.0.1:6379> LPUSH list 1
(integer) 1
127.0.0.1:6379> LRANGE list 0 -1
1) "1"
127.0.0.1:6379> STRLEN list
(error) WRONGTYPE Operation against a key holding the wrong kind of value

#当key不存在的情况返回0

127.0.0.1:6379> STRLEN key4
(integer) 0

#将自增自减和GETSET先获取后重置放一起介绍

INCR key

对存储在指定key的数值执行原子的加1操作。

如果指定的key不存在,那么在执行incr操作之前,会先将它的值设定为0

如果指定的key中存储的值不是字符串类型(fix:)或者存储的字符串类型不能表示为一个整数,

那么执行这个命令时服务器会返回一个错误(eq:(error) ERR value is not an integer or out of range)。

这个操作仅限于64位的有符号整型数据

#情况1key不存在,会从0自增

127.0.0.1:6379> INCR key5
(integer) 1
127.0.0.1:6379> get key5
"1"

#情况2key不可以转成整数

127.0.0.1:6379> set key7 test
OK
127.0.0.1:6379> INCR key7
(error) ERR value is not an integer or out of range

#情况3key是浮点数,结果和上面一致

127.0.0.1:6379> set key6 3.1
OK
127.0.0.1:6379> INCR key6
(error) ERR value is not an integer or out of range

#情况4正常情况

127.0.0.1:6379> set key4 1
OK
127.0.0.1:6379> get key4
"1"
127.0.0.1:6379> INCR key4
(integer) 2
127.0.0.1:6379> get key4
"2"  

DECR key

对key对应的数字做减1操作。如果key不存在,那么在操作之前,这个key对应的值会被置为0。如果key有一个错误类型的value或者是一个不能表示成数字的字符串,就返回错误。这个操作最大支持在64位有符号的整型数字。

#不做描述,情景和自增INCR一致

GETSET key value

自动将key对应到value并且返回原来key对应的value。如果key存在但是对应的value不是字符串,就返回错误。

127.0.0.1:6379> INCR key8
(integer) 1

127.0.0.1:6379> GETSET key8 2
"1"
127.0.0.1:6379> get key8
"2"

#批量设置和获取 略,和set类似。具体可以查看redis手册

posted on 2018-03-04 23:20  invokermiracle  阅读(285)  评论(0编辑  收藏  举报