#设置值
SET key value [EX seconds] [PX milliseconds] [NX|XX]
SET
命令加上选项已经可以完全取代SETNX, SETEX, PSETEX的功能,所以在将来的版本中,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手册