一文搞定Redis五大数据类型及使用场景

字符串
1.1 内部编码
int:8个字节的长整型。 embstr:小于等于39个字节的字符串。 raw:大于39个字节的字符串。
1.2 使用场景
1.2.1 缓存
1.2.2 计数
值不是整数,返回错误 值是整数,返回自增后的结果 key不存在,默认键为0,返回1
1.2.3 共享Session
1.2.4 限速

2.1 内部编码
ziplist(压缩列表):当哈希类型元素个数小于hash-max-ziplist-entries配置(默认512个)同时所有值都小于hash-max-ziplist-value配置(默认64字节)时使用。ziplist使用更加紧凑的结构实现多个元素的连续存储,所以比hashtable更加节省内存。 hashtable(哈希表):当ziplist不能满足要求时,会使用hashtable。
2.2 使用场景
id | name | age |
---|---|---|
1 | Java旅途 | 18 |
hset user:1 name Java旅途 age 18

列表
3.1 内部编码
ziplist(压缩列表):当哈希类型元素个数小于list-max-ziplist-entries配置(默认512个)同时所有值都小于list-max-ziplist-value配置(默认64字节)时使用。ziplist使用更加紧凑的结构实现多个元素的连续存储,所以比hashtable更加节省内存。 linkedlist(链表):当ziplist不能满足要求时,会使用linkedlist。
3.2 使用场景
3.2.1 消息队列
3.2.2 栈
3.2.3 文章列表

集合
4.1 内部编码
intset(整数集合):当集合中的元素都是整数且元素个数小于set-max-intset-entries配置(默认512个)时,redis会选用intset来作为集合的内部实现,从而减少内存的使用。 hashtable(哈希表):当intset不能满足要求时,会使用hashtable。
4.2 使用场景
4.2.1 用户标签
给用户打标签
sadd user:1:tags tag1 tag2
给标签添加用户
sadd tag1:users user:1
sadd tag2:users user:1
sinter user:1:tags user:2:tags
4.2.2 抽奖功能
随机获取count个元素,集合元素个数不变
srandmember key [count]
随机弹出count个元素,元素从集合弹出,集合元素个数改变
spop key [count]

有序集合
5.1 内部编码
ziplist(压缩列表):当有序集合的元素个数小于list-max-ziplist-entries配置(默认128个)同时所有值都小于list-max-ziplist-value配置(默认64字节)时使用。ziplist使用更加紧凑的结构实现多个元素的连续存储,更加节省内存。 skiplist(跳跃表):当不满足ziplist的要求时,会使用skiplist。
5.2 使用场景
5.2.1 排行榜
zadd user:article 0 a
zincrby user:article 1 a
zrevrangebyscore user:article 0 2
zrangebyscore user:article 0 2
5.2.2 延迟消息队列

总结
更多精彩推荐
点分享 点点赞 点在看
关注公众号:拾黑(shiheibook)了解更多
[广告]赞助链接:
四季很好,只要有你,文娱排行榜:https://www.yaopaiming.com/
让资讯触达的更精准有趣:https://www.0xu.cn/

随时掌握互联网精彩
赞助链接
排名
热点
搜索指数
- 1 增绿就是增优势 植树就是植未来 7949479
- 2 驻外人员嫖娼遭威胁 向间谍大量泄密 7902851
- 3 17万的哪吒增程车成了老头乐 7872595
- 4 《政府工作报告》全文公布 7712061
- 5 老外为证明没说谎带邻居来中国 7662211
- 6 女歌手全国巡回演唱会后被抓 7592240
- 7 公司回应广告牌上女士有6根手指 7488333
- 8 法源寺600多岁的石狮子被游客推倒 7369166
- 9 演员邓晓光去世 曾出演《水浒》花荣 7238003
- 10 韩国娱乐圈为何命案频发 7168422