redis-data-types.md 3.8 KB
Newer Older
Y
yanglbme 已提交
1
## 面试题
Y
yanglbme 已提交
2

Y
yanglbme 已提交
3
Redis 都有哪些数据类型?分别在哪些场景下使用比较合适?
Y
yanglbme 已提交
4 5

## 面试官心理分析
Y
yanglbme 已提交
6

Y
yanglbme 已提交
7 8 9
除非是面试官感觉看你简历,是工作 3 年以内的比较初级的同学,可能对技术没有很深入的研究,面试官才会问这类问题。否则,在宝贵的面试时间里,面试官实在不想多问。

其实问这个问题,主要有两个原因:
Y
yanglbme 已提交
10

Y
yanglbme 已提交
11 12
- 看看你到底有没有全面的了解 Redis 有哪些功能,一般怎么来用,啥场景用什么,就怕你别就会最简单的 KV 操作;
- 看看你在实际项目里都怎么玩儿过 Redis。
Y
yanglbme 已提交
13 14 15 16

要是你回答的不好,没说出几种数据类型,也没说什么场景,你完了,面试官对你印象肯定不好,觉得你平时就是做个简单的 set 和 get。

## 面试题剖析
Y
yanglbme 已提交
17

Y
yanglbme 已提交
18
Redis 主要有以下几种数据类型:
Y
yanglbme 已提交
19

Y
yanglbme 已提交
20 21 22 23 24
- Strings
- Hashes
- Lists
- Sets
- Sorted Sets
Y
yanglbme 已提交
25

Y
yanglbme 已提交
26 27 28
> Redis 除了这 5 种数据类型之外,还有 Bitmaps、HyperLogLogs、Streams 等。

### Strings
Y
yanglbme 已提交
29

Y
yanglbme 已提交
30
这是最简单的类型,就是普通的 set 和 get,做简单的 KV 缓存。
Y
yanglbme 已提交
31

Y
yanglbme 已提交
32
```bash
Y
yanglbme 已提交
33 34 35
set college szu
```

Y
yanglbme 已提交
36
### Hashes
Y
yanglbme 已提交
37

Y
yanglbme 已提交
38
这个是类似 map 的一种结构,这个一般就是可以将结构化的数据,比如一个对象(前提是**这个对象没嵌套其他的对象**)给缓存在 Redis 里,然后每次读写缓存的时候,可以就操作 hash 里的**某个字段**
Y
yanglbme 已提交
39

Y
yanglbme 已提交
40
```bash
Y
yanglbme 已提交
41 42 43 44 45 46
hset person name bingo
hset person age 20
hset person id 1
hget person name
```

Y
yanglbme 已提交
47 48 49 50 51 52
```json
(person = {
  "name": "bingo",
  "age": 20,
  "id": 1
})
Y
yanglbme 已提交
53 54
```

Y
yanglbme 已提交
55
### Lists
Y
yanglbme 已提交
56

Y
yanglbme 已提交
57
Lists 是有序列表,这个可以玩儿出很多花样。
Y
yanglbme 已提交
58

Y
yanglbme 已提交
59
比如可以通过 list 存储一些列表型的数据结构,类似粉丝列表、文章的评论列表之类的东西。
Y
yanglbme 已提交
60

Y
yanglbme 已提交
61
比如可以通过 lrange 命令,读取某个闭区间内的元素,可以基于 list 实现分页查询,这个是很棒的一个功能,基于 Redis 实现简单的高性能分页,可以做类似微博那种下拉不断分页的东西,性能高,就一页一页走。
Y
yanglbme 已提交
62

Y
yanglbme 已提交
63
```bash
Y
yanglbme 已提交
64 65 66 67 68
# 0开始位置,-1结束位置,结束位置为-1时,表示列表的最后一个位置,即查看所有。
lrange mylist 0 -1
```

比如可以搞个简单的消息队列,从 list 头怼进去,从 list 尾巴那里弄出来。
Y
yanglbme 已提交
69

Y
yanglbme 已提交
70
```bash
Y
yanglbme 已提交
71 72 73 74 75 76 77 78
lpush mylist 1
lpush mylist 2
lpush mylist 3 4 5

# 1
rpop mylist
```

Y
yanglbme 已提交
79
### Sets
Y
yanglbme 已提交
80

Y
yanglbme 已提交
81
Sets 是无序集合,自动去重。
Y
yanglbme 已提交
82

Y
yanglbme 已提交
83
直接基于 set 将系统里需要去重的数据扔进去,自动就给去重了,如果你需要对一些数据进行快速的全局去重,你当然也可以基于 jvm 内存里的 HashSet 进行去重,但是如果你的某个系统部署在多台机器上呢?得基于 Redis 进行全局的 set 去重。
Y
yanglbme 已提交
84 85 86

可以基于 set 玩儿交集、并集、差集的操作,比如交集吧,可以把两个人的粉丝列表整一个交集,看看俩人的共同好友是谁?对吧。

Y
yanglbme 已提交
87
把两个大 V 的粉丝都放在两个 set 中,对两个 set 做交集。
Y
yanglbme 已提交
88

Y
yanglbme 已提交
89
```bash
Y
yanglbme 已提交
90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123
#-------操作一个set-------
# 添加元素
sadd mySet 1

# 查看全部元素
smembers mySet

# 判断是否包含某个值
sismember mySet 3

# 删除某个/些元素
srem mySet 1
srem mySet 2 4

# 查看元素个数
scard mySet

# 随机删除一个元素
spop mySet

#-------操作多个set-------
# 将一个set的元素移动到另外一个set
smove yourSet mySet 2

# 求两set的交集
sinter yourSet mySet

# 求两set的并集
sunion yourSet mySet

# 求在yourSet中而不在mySet中的元素
sdiff yourSet mySet
```

Y
yanglbme 已提交
124
### Sorted Sets
Y
yanglbme 已提交
125

Y
yanglbme 已提交
126
Sorted Sets 是排序的 set,去重但可以排序,写进去的时候给一个分数,自动根据分数排序。
Y
yanglbme 已提交
127

Y
yanglbme 已提交
128
```bash
Y
yanglbme 已提交
129 130 131 132 133 134 135 136 137 138
zadd board 85 zhangsan
zadd board 72 lisi
zadd board 96 wangwu
zadd board 63 zhaoliu

# 获取排名前三的用户(默认是升序,所以需要 rev 改为降序)
zrevrange board 0 3

# 获取某用户的排名
zrank board zhaoliu
Y
yanglbme 已提交
139
```