1 Redis数据结构介绍
Redis 是一个 key-value 的数据库,key 一般是 String 类型,不过 value 的类型多种多样。
- 基本类型
- String: hello world
- Hash: {name: "Jack", age: 21}
- List: [A -> B -> C -> C]
- Set: {A, B, C}
- SortedSet: {A:1, B:2, C:3}
- 特殊类型
- GEO: {A:(120.3, 30.5)}
- BitMap: 011011010100110101
- HyperLog: 011011010100110101
2 Redis通用命令
帮助 help @generic
。
常用命令:
-
keys pattern
: 查看符合模板的所有 key。不建议在生产环境设备上使用。 del key [key ...]
exists key [key ...]
-
expire key seconds
: 给一个 key 设置有效期,到期后被删除 -
ttl key
: 查看一个 key 的剩余有效期
3 String类型
String 类型,也就是字符串类型,是 Redis 中最简单的存储类型。其 value 是字符串,不过根据字符串的格式不同,又可以分为 3 类。
- string: 普通字符串
- int: 整数类型,可以做自增、自减操作
- float: 浮点类型,可以做自增、自减操作
不管是哪种格式,底层都是字节数组形式存储,只不过编码方式不同。字符串类型的最大空间不超过 512m。
命令:
-
set
: 添加或修改已经存在的一个 String 类型的键值对 -
get
: 获取值 -
mset
: 批量添加或修改 -
mget
: 批量获取值 -
incr
: 指定 key 自增 -
incrby
: 指定 key 自增指定值 -
incrbyfloat
: 指定 key 视为小数,自增指定值 -
setnx
: set no exist -
setex
: set and expire
key 的结构:Redis 的 key 允许有多个单词形成层级结构,多个单词之间用 :
隔开。例如:项目名:业务名:类型:id
。
这个格式并非固定,也可以根据自己的需求来删除或添加词条。
例如,我们的项目名称叫 heima,有 user 和 product 两种不同类型的数据,我们可以这样定义 key:
- user 相关的 key:
heima:user:1
- product 相关的 key:
heima:product:1
4 hash类型
Hash 类型,也叫散列,其 value 是一个无序字典,类似于 Java 中的 HashMap 结构。
String 结构是将对象序列化为 JSON 字符串后存储,当需要修改对象某个字段时很不方便。Hash 结构可以将对象中的每个字段独立存储,可以针对单个字段进行 CRUD。
Hash 类型的常见命令:
-
hset key field value
: 添加或修改hash类型key的field值 -
hget key field
: 获取一个 hash 类型 key 的field 值 -
hmget key field [field ...]
: 获取多个字段值 -
hgetall key
: 获取一个 hash 类型的 key 中的所有 field -
hkeys key
: 获取一个 hash 类型的 key 中的所有 field -
hvals key
: 获取一个 hash 类型的 key 中的所有 value -
hincrby key field increment
: 让一个 hash 类型 key 的字段自增并指定步长 -
hsetnx key field value
: 如果 key 的 field 字段不存在,则设置该字段的值
5 list类型
Redis 中的 List 类型与 Java 中的 LinkedList 类似,可以看作是一个双向链表结构。既可以支持正向索引,也可以支持反向检索。
特征业余 LinkedList 类似:
- 有序
- 元素可以重复
- 插入和删除快
- 查询速度一般
List 常见命令:
-
lpush
: 向列表左侧插入一个或多个元素 -
rpush
: 向列表右侧插入一个或多个元素 -
lpop
: 移除并返回列表左侧的第一个元素,没有返回 nil -
rpop
: 移除并返回列表右侧的第一个元素,没有返回 nil -
lrange
: 返回一段角标范围内的所有元素 -
blpop
和brpop
: 与 lpop 和 rpop 类似,只不过 b 表示 block,在没有元素时等待指定时间,而不是直接返回 nil
6 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 key
: 获取 set 中的元素 -
sinter key1 key2 ...
: 求多个集合的交集 -
sunion key1 key2 ...
: 求多个集合的并集 -
sdiff key1 key2 ..
: 求多个集合的差集
7 SortedSet类型
Redis 的 SortedSet 是一个可排序的 set 集合,与 java 中的 TreeSet 类似,但底层数据结构差别很大。SortedSet 中的每一个元素都带有一个 score 属性,可以基于 score 属性对元素排序,底层的实现是一个跳表(SkipList)加hash表。
SortedSet 具备以下特性:
- 可排序
- 元素不重复
- 查询速度快
因为 SortedSet 的可排序特性,经常被用来实现排行榜这样的功能。
-
zadd key score member
: 添加或修改元素 -
zrem key member
: 删除元素 -
zscore key member
: 查询分数 -
zrank key member
: 查询排名 -
zcard key
: 查询元素个数 -
zcount key min max
: 统计 score 值在指定范围内的所有元素个数 -
zincrby key increment member
: 自增 -
zrange key min max
: 按 score 排序后,获取指定排名范围内的元素 -
zrangebyscore key min max
: 按 score 排序后,获取 score 范围内的元素 -
zdiff
/zinter
/zunion
降序在 z
后加 rev
。