# Redis 基础

# Redis 数据结构介绍

Redis 是一个 key-value 的数据库,key 一般是 String 类型,不过 value 的类型多种多样

value 类型示例
Stringhello world
Hash
List[A -> B -> C -> C]
Set
SortedSet
GEO
BitMap01101100101011011
HyperLog01010101101001101

# Redis 通用命令

通用命令是部分数据类型的,都可以使用的命令,常见的有 :

  • KEYS: 查看符合模板的所有 key, 不建议在生产环境设备上使用

    image-20221214151911943

  • DEL: 删除一个指定的 key

    image-20221214152130697

  • EXISTS: 判断 key 是否存在

    image-20221214152329417

  • EXPIRE: 给一个 key 设置有效期,有效期到期时该 key 会被自动删除

    image-20221214152452644

  • TTL: 查看一个 KEY 的剩余有效期

    image-20221214152526762

# 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 类型的键值对,并且指定有效期

# key 的层级格式

Redis 的 key 允许有多个单词形成的层级结构,多个单词之间用 “:” 隔开,格式如下 :

项目名:业务名:类型:id

这个格式并非固定,也可以根据自己的需求来删除或添加词条

# Hash 类型

Hash 类型,也叫散列,其 value 是一个无序字典,类似于 Java 中的 HashMap 结构

# 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
  • HVALS: 获取一个 hash 类型的 key 中的所有的 value
  • HINCRBY: 让一个 hash 类型的 key 的字段值自增并指定步长
  • HSETNX: 添加一个 hash 类型的 key 的 field 值,前提是这个 field 不存在,否则不执行

# List 类型

Redis 中的 List 类型与 Java 中的 LinkedList 类似,可以看作是一个双向链表结构。既可以支持正向检索也可以支持反向检索

特征也与 LinkedList 类似

  • 有序
  • 元素可以重复
  • 插入和删除快
  • 查询速度一般

# List 类型的常见命令

  • LPUSH key element …: 向列表左侧插入一个或多个元素
  • LPOP key: 移除并返回列表左侧的第一个元素,没有则返回 nil
  • RPUSH key element …: 像列表右侧插入一个或多个元素
  • RPOP key: 移除并返回列表右侧的第一个元素
  • LRANGE key start end: 返回一段角标范围内的所有元素
  • BLPOP 和 BRPOP: 与 LPOP 和 RPOP 类似,只不过在没有元素时等待指定时间,而不是直接返回 nil

# 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 的并集

# SortedSet 类型

Redis 的 SortedSet 是一个可排序的 set 集合,与 Java 中的 TreeSet 有些类似,但底层数据结构却差别很大. SortedSet 的每个元素都带有一个 score 属性,可以基于 score 属性对元素排序,底层的实现是一个跳表 (SkipList) 加 hash 表

SortedSet 具备下列特性:

  • 可排序
  • 元素不重复
  • 查询速度快

因为 SortedSet 的可排序特性,进常被用来实现排行榜这样的功能

# SortedSet 类型的常见命令

  • ZADD key score member: 添加一个或多个元素到 sortedset, 如果存在则更新其 score 值
  • ZREM key member: 删除 sortedset 中的一个指定元素
  • ZSCORE key member: 获取 sortedset 中的指定元素的 score 值
  • ZRANK key member: 获取 sortedset 中的指定元素的排名
  • ZCARD key: 获取 sortedset 中的元素个数
  • ZCOUNT key min max: 统计 score 值在给定范围内的所有元素的个数
  • ZINCRBY key increment member: 让 sortedset 中的指定元素自增,步长为指定的 increment 值
  • ZRANGE key min max: 按照 score 排序后,获取指定排名范围内的元素
  • ZRANGEBYSCORE key min max: 按照 score 排序后,获取指定 score 范围内的元素
  • ZDIFF, ZINTER, ZUNION: 求差集,交集,并集