# ☎️Redis 常见命令
# 📞Redis 数据结构介绍
Redis 为了方便我们学习,将操作不同数据类型的命令也做了分组,在官网( https://redis.io/commands )可以查看到不同的命令:
当然我们也可以通过 Help 命令来帮助我们去查看命令
# 📞Redis 通用命令
- KEYS:查看符合模板的所有 key
- DEL:删除一个指定的 key
- EXISTS:判断 key 是否存在
- EXPIRE:给一个 key 设置有效期,有效期到期时该 key 会被自动删除
- TTL:查看一个 KEY 的剩余有效期
通过 help [command] 可以查看一个命令的具体用法,例如:
# 📞Redis 命令 —— String 命令
String 类型,也就是字符串类型,是 Redis 中最简单的存储类型。
其 value 是字符串,不过根据字符串的格式不同,又可以分为 3 类:
- string:普通字符串
- int:整数类型,可以做自增。自减操作
- float:浮点类型,可以做自增。自减操作
String 的常见命令有:
- SET:添加或者修改已经存在的一个 String 类型的键值对
- GET:根据 key 获取 String 类型的 value
- MSET:批量添加多个 String 类型的键值对
- MGET:根据多个 key 获取多个 String 类型的 value
- INCR:让一个整型的 key 自增 1
- INCRBY: 让一个整型的 key 自增并指定步长,例如:incrby num 2 让 num 值自增 2
- INCRBYFLOAT:让一个浮点类型的数字自增并指定步长
- SETNX:添加一个 String 类型的键值对,前提是这个 key 不存在,否则不执行
- SETEX:添加一个 String 类型的键值对,并且指定有效期
SET 和 GET: 如果 key 不存在则是新增,如果存在则是修改
# 📞Redis 命令 —— Key 的层级结构
Redis 的 key 允许有多个单词形成层级结构,多个单词之间用 ':' 隔开,格式如下:
这个格式并非固定,也可以根据自己的需求来删除或添加词条。
# 📞Redis 命令 —— Hash 命令
Hash 类型,也叫散列,其 value 是一个无序字典,类似于 Java 中的 HashMap 结构。
String 结构是将对象序列化为 JSON 字符串后存储,当需要修改对象某个字段时很不方便:
Hash 结构可以将对象中的每个字段独立存储,可以针对单个字段做 CRUD:
Hash 类型的常见命令
HSET key field value:添加或者修改 hash 类型 key 的 field 的值
HGET key field:获取一个 hash 类型 key 的 field 的值
HMSET:批量添加多个 hash 类型 key 的 field 的值
HMGET:批量获取多个 hash 类型 key 的 field 的值
HGETALL:获取一个 hash 类型的 key 中的所有的 field 和 value
HKEYS:获取一个 hash 类型的 key 中的所有的 field
HINCRBY: 让一个 hash 类型 key 的字段值自增并指定步长
HSETNX:添加一个 hash 类型的 key 的 field 值,前提是这个 field 不存在,否则不执行
# 📞Redis 命令 —— List 命令
Redis 中的 List 类型与 Java 中的 LinkedList 类似,可以看做是一个双向链表结构。既可以支持正向检索和也可以支持反向检索。
特征也与 LinkedList 类似:
- 有序
- 元素可以重复
- 插入和删除快
- 查询速度一般
常用来存储一个有序数据,例如:朋友圈点赞列表,评论列表等。
List 的常见命令有:
- LPUSH key element ... :向列表左侧插入一个或多个元素
- LPOP key:移除并返回列表左侧的第一个元素,没有则返回 nil
- RPUSH key element ... :向列表右侧插入一个或多个元素
- RPOP key:移除并返回列表右侧的第一个元素
- LRANGE key star end:返回一段角标范围内的所有元素
- BLPOP 和 BRPOP:与 LPOP 和 RPOP 类似,只不过在没有元素时等待指定时间,而不是直接返回 nil
# 📞Redis 命令 —— Set 命令
Redis 的 Set 结构与 Java 中的 HashSet 类似,可以看做是一个 value 为 null 的 HashMap。因为也是一个 hash 表,因此具备与 HashSet 类似的特征:
- 无序
- 元素不可重复
- 查找快
- 支持交集。并集。差集等功能
Set 类型的常见命令
- SADD key member ... :向 set 中添加一个或多个元素
- SREM key member ... : 移除 set 中的指定元素
- SCARD key: 返回 set 中元素的个数
- SISMEMBER key member:判断一个元素是否存在于 set 中
- SMEMBERS:获取 set 中的所有元素
- SINTER key1 key2 ... :求 key1 与 key2 的交集
- SDIFF key1 key2 ... :求 key1 与 key2 的差集
- SUNION key1 key2 ..:求 key1 和 key2 的并集
# 📞Redis 命令 —— SortedSet 类型
Redis 的 SortedSet 是一个可排序的 set 集合,与 Java 中的 TreeSet 有些类似,但底层数据结构却差别很大。SortedSet 中的每一个元素都带有一个 score 属性,可以基于 score 属性对元素排序,底层的实现是一个跳表(SkipList)加 hash 表。
SortedSet 具备下列特性:
- 可排序
- 元素不重复
- 查询速度快
因为 SortedSet 的可排序特性,经常被用来实现排行榜这样的功能。
SortedSet 的常见命令有:
- ZADD key score member:添加一个或多个元素到 sorted set ,如果已经存在则更新其 score 值
- ZREM key member:删除 sorted set 中的一个指定元素
- ZSCORE key member : 获取 sorted set 中的指定元素的 score 值
- ZRANK key member:获取 sorted set 中的指定元素的排名
- ZCARD key:获取 sorted set 中的元素个数
- ZCOUNT key min max:统计 score 值在给定范围内的所有元素的个数
- ZINCRBY key increment member:让 sorted set 中的指定元素自增,步长为指定的 increment 值
- ZRANGE key min max:按照 score 排序后,获取指定排名范围内的元素
- ZRANGEBYSCORE key min max:按照 score 排序后,获取指定 score 范围内的元素
- ZDIFF.ZINTER.ZUNION:求差集。交集。并集
所有的排名默认都是升序,如果要降序则在命令的 Z 后面添加 REV 即可,例如:
- 升序获取 sorted set 中的指定元素的排名:ZRANK key member
- 降序获取 sorted set 中的指定元素的排名:ZREVRANK key memeber
# ☎️Redis 的 Java 客户端 —— SpringDataRedis
SpringData 是 Spring 中数据操作的模块,包含对各种数据库的集成,其中对 Redis 的集成模块就叫做 SpringDataRedis,官网地址:https://spring.io/projects/spring-data-redis
- 提供了对不同 Redis 客户端的整合(Lettuce 和 Jedis)
- 提供了 RedisTemplate 统一 API 来操作 Redis
- 支持 Redis 的发布订阅模型
- 支持 Redis 哨兵和 Redis 集群
- 支持基于 Lettuce 的响应式编程
- 支持基于 JDK.JSON. 字符串.Spring 对象的数据序列化及反序列化
- 支持基于 Redis 的 JDKCollection 实现
SpringDataRedis 中提供了 RedisTemplate 工具类,其中封装了各种对 Redis 的操作。并且将不同数据类型的操作 API 封装到了不同的类型中:
SpringDataRedis 的使用步骤:
- 引入 spring-boot-starter-data-redis 依赖
- 在 application.yml 配置 Redis 信息
- 注入 RedisTemplate
# 📞Redis 数据序列化
RedisTemplate 的两种序列化实践方案:
方案一:
- 自定义 RedisTemplate
- 修改 RedisTemplate 的序列化器为 GenericJackson2JsonRedisSerializer
方案二:
- 使用 StringRedisTemplate
- 写入 Redis 时,手动把对象序列化为 JSON
- 读取 Redis 时,手动把读取到的 JSON 反序列化为对象