Redis高频面试题之缓存穿透、缓存击穿和缓存雪崩,Java开发者跳槽面试

(integer) 0

127.0.0.1:6379> ttl name #如若返回-2,证明key已过期

(integer) -2

127.0.0.1:6379> get name #再次查询即为空

(nil)

127.0.0.1:6379> type name1

string

127.0.0.1:6379>




_**如若遇到不会的命令!记得查看Redis中文官网,上面有官方文档!链接上面有,可以点击跳转~**_



[]( )二、Redis的五大数据类型

---------------------------------------------------------------------------------



1.  String(字符串)



①**添加**、**查询**、**追加**、**获取长度**,**判断是否存在**的操作



127.0.0.1:6379> set name dingdada #插入一个key为‘name’值为‘dingdada’的数据

OK

127.0.0.1:6379> get name #获取key为‘name’的数据

“dingdada”

127.0.0.1:6379> get key1

“hello world!”

127.0.0.1:6379> keys * #查看当前库的所有数据

  1. “name”

127.0.0.1:6379> EXISTS name #判断key为‘name’的数据存在不存在,存在返回1

(integer) 1

127.0.0.1:6379> EXISTS name1 #不存在返回0

(integer) 0

127.0.0.1:6379> APPEND name1 dingdada1 #追加到key为‘name’的数据后拼接值为‘dingdada1’,如果key存在类似于java中字符串‘+’,不存在则新增一个,类似于Redis中的set name1 dingdada1 ,并且返回该数据的总长度

(integer) 9

127.0.0.1:6379> get name1

“dingdada1”

127.0.0.1:6379> STRLEN name1 #查看key为‘name1’的字符串长度

(integer) 9

127.0.0.1:6379> APPEND name1 ,dingdada2 #追加,key存在的话,拼接‘+’,返回总长度

(integer) 19

127.0.0.1:6379> STRLEN name1

(integer) 19

127.0.0.1:6379> get name1

“dingdada1,dingdada2”

127.0.0.1:6379> set key1 “hello world!” #注意点:插入的数据中如果有空格的数据,请用“”双引号,否则会报错!

OK

127.0.0.1:6379> set key1 hello world! #报错,因为在Redis中空格就是分隔符,相当于该参数已结束

(error) ERR syntax error

127.0.0.1:6379> set key1 hello,world! #逗号是可以的

OK




②**自增**、**自减**操作



127.0.0.1:6379> set num 0 #插入一个初始值为0的数据

OK

127.0.0.1:6379> get num

“0”

127.0.0.1:6379> incr num #指定key为‘num’的数据自增1,返回结果 相当于java中 i++

(integer) 1

127.0.0.1:6379> get num #一般用来做文章浏览量、点赞数、收藏数等功能

“1”

127.0.0.1:6379> incr num

(integer) 2

127.0.0.1:6379> incr num

(integer) 3

127.0.0.1:6379> get num

“3”

127.0.0.1:6379> decr num #指定key为‘num’的数据自减1,返回结果 相当于java中 i–

(integer) 2

127.0.0.1:6379> decr num

(integer) 1

127.0.0.1:6379> decr num

(integer) 0

127.0.0.1:6379> decr num #可以一直减为负数~

(integer) -1

127.0.0.1:6379> decr num #一般用来做文章取消点赞、取消收藏等功能

(integer) -2

127.0.0.1:6379> decr num

(integer) -3

127.0.0.1:6379> INCRBY num 10 #后面跟上by 指定key为‘num’的数据自增‘参数(10)’,返回结果

(integer) 7

127.0.0.1:6379> INCRBY num 10

(integer) 17

127.0.0.1:6379> DECRBY num 3 #后面跟上by 指定key为‘num’的数据自减‘参数(3)’,返回结果

(integer) 14

127.0.0.1:6379> DECRBY num 3

(integer) 11




③**截取**、**替换**字符串操作



#截取

127.0.0.1:6379> set key1 “hello world!”

OK

127.0.0.1:6379> get key1

“hello world!”

127.0.0.1:6379> GETRANGE key1 0 4 #截取字符串,相当于java中的subString,下标从0开始,不会改变原有数据

“hello”

127.0.0.1:6379> get key1

“hello world!”

127.0.0.1:6379> GETRANGE key1 0 -1 #0至-1相当于 get key1,效果一致,获取整条数据

“hello world!”

#替换

127.0.0.1:6379> set key2 “hello,world!”

OK

127.0.0.1:6379> get key2

“hello,world!”

127.0.0.1:6379> SETRANGE key2 5 888 #此语句跟java中replace有点类似,下标也是从0开始,但是有区别:java中是指定替换字符,Redis中是从指定位置开始替换,替换的数据根据你所需替换的长度一致,返回值是替换后的长度

(integer) 14

127.0.0.1:6379> get key2

“hello888world!”

127.0.0.1:6379> SETRANGE key2 5 67 #该处只替换了两位

(integer) 14

127.0.0.1:6379> get key2

“hello678world!”




④**设置过期时间**、**不存在设置**操作



#设置过期时间,跟Expire的区别是前者设置已存在的key的过期时间,而setex是在创建的时候设置过期时间

127.0.0.1:6379> setex name1 15 dingdada #新建一个key为‘name1’,值为‘dingdada’,过期时间为15秒的字符串数据

OK

127.0.0.1:6379> ttl name1 #查看key为‘name1’的key的过期时间

(integer) 6

127.0.0.1:6379> ttl name1

(integer) 5

127.0.0.1:6379> ttl name1

(integer) 3

127.0.0.1:6379> ttl name1

(integer) 1

127.0.0.1:6379> ttl name1

(integer) 0

127.0.0.1:6379> ttl name1 #返回为-2时证明该key已过期,即不存在

(integer) -2

#不存在设置

127.0.0.1:6379> setnx name2 dingdada2 #如果key为‘name2’不存在,新增数据,返回值1证明成功

(integer) 1

127.0.0.1:6379> get name2

“dingdada2”

127.0.0.1:6379> keys *

  1. “name2”

127.0.0.1:6379> setnx name2 “dingdada3” #如果key为‘name2’的已存在,设置失败,返回值0,也就是说这个跟set的区别是:set会替换原有的值,而setnx不会,存在即不设置,确保了数据误操作~

(integer) 0

127.0.0.1:6379> get name2

“dingdada2”




⑤**mset**、**mget**操作



127.0.0.1:6379> mset k1 v1 k2 v2 k3 v3 #插入多条数据

OK

127.0.0.1:6379> keys * #查询所有数据

  1. “k2”

  2. “k3”

  3. “k1”

127.0.0.1:6379> mget k1 k2 k3 #查询key为‘k1’,‘k2’,‘k3’的数据

  1. “v1”

  2. “v2”

  3. “v3”

127.0.0.1:6379> MSETNX k1 v1 k4 v4 #msetnx是一个原子性的操作,在一定程度上保证了事务!要么都成功,要么都失败!相当于if中的条件&&(与)

(integer) 0

127.0.0.1:6379> keys *

  1. “k2”

  2. “k3”

  3. “k1”

127.0.0.1:6379> MSETNX k5 v5 k4 v4 #全部成功

(integer) 1

127.0.0.1:6379> keys *

  1. “k2”

  2. “k4”

  3. “k3”

  4. “k5”

  5. “k1”




⑥**添加获取对象**、**getset**操作



上一篇:Redis基础:


下一篇:redis的list命令总结