Redis类型及使用场景总结

Redis支持数据的持久化,可以将内存中的数据保存在磁盘中,重启的时候可以再次加载进行使用。
Redis不仅仅支持简单的key-value类型的数据,同时还提供list,set,zset,hash等数据结构的存储。
Redis支持数据的备份,即master-slave模式的数据备份。

数据类型及使用场景总结:

类型 特点 使用场景
string(字符串) 二进制安全的,就是可以包含任何数据,比如jpg图片或者序列化的对象。 验证码、token等
hash(哈希) 是一个 string 类型的 field 和 value 的映射表,特别适合用于存储对象 存储用户信息、购物车、详情页等
list(列表) 双向链表,添加一个元素到列表的左边或右边 最新消息排行(评论列表)、消息队列等
set(集合) 通过哈希表实现,无序集合、唯一 抽奖随机事件、共同好友、统计网站的所有ip、数组处理等
sorted set(有序集合) 有序集合、唯一 排行榜等

常见使用场景例子:
① (活跃)用户统计
查看任意时间用户的登录天数

127.0.0.1:6379> SETBIT user1 0 1     # 第1天登录
(integer) 0
127.0.0.1:6379> SETBIT user1 2 1     # 第3天登录
(integer) 0
127.0.0.1:6379> SETBIT user1 3 1     # 第4天登录
(integer) 0
127.0.0.1:6379> BITCOUNT user1 0 -1    # 求user1总共登录天数,返回3
(integer) 3


127.0.0.1:6379> SETBIT 01/01 1 1    # 用户1在01/01登录
(integer) 0
127.0.0.1:6379> SETBIT 01/02 2 1    # 用户2在01/02登录
(integer) 0
127.0.0.1:6379> BITOP OR orKey 01/01 01/02  #求01/01、01/02这两天登录用户数,这里取or
(integer) 1
127.0.0.1:6379> BITCOUNT orKey # 求01/01、01/02这两天登录用户数,返回2
(integer) 2
127.0.0.1:6379> SETBIT 01/02 1 1    # 用户1在01/02也登录了
(integer) 0
127.0.0.1:6379> BITOP OR orKey 01/01 01/02    # 取or
(integer) 1
127.0.0.1:6379> BITCOUNT orKey  # 求01/01、01/02这两天登录用户数,返回2,因为这两天只有用户1和用户2登录,所以只有2个人
(integer) 2

② 评论列表(list列表)
list类型的LTRIM命令
对一个列表进行修剪(trim),就是说,让列表只保留指定区间内的元素,不在指定区间之内的元素都将被删除。

127.0.0.1:6379> lpush list d1 d2 d3 d4 d5 d6
(integer) 6
127.0.0.1:6379> lrange list 0 -1
1) "d6"
2) "d5"
3) "d4"
4) "d3"
5) "d2"
6) "d1"
127.0.0.1:6379> ltrim list 0 -3
OK
127.0.0.1:6379> lrange list 0 -1
1) "d6"
2) "d5"
3) "d4"
4) "d3"

③ 抽奖随机事件(set集合)

127.0.0.1:6379> sadd k1 d1 d2 d3 d2
(integer) 3
127.0.0.1:6379> smembers k1
1) "d3"
2) "d1"
3) "d2"
127.0.0.1:6379> srandmember k1 5
1) "d1"
2) "d3"
3) "d2"
127.0.0.1:6379> srandmember k1 -5
1) "d1"
2) "d1"
3) "d2"
4) "d2"
5) "d2"

// 抽奖,不重复单个人抽奖
127.0.0.1:6379> spop k1
"d2"
127.0.0.1:6379> spop k1
"d1"
127.0.0.1:6379> spop k1
"d3"
127.0.0.1:6379> spop k1
(nil)
127.0.0.1:6379>

// 数组处理,可用于好友推荐系统等
127.0.0.1:6379> sadd k1 a b c d  // 添加k1集合
(integer) 4
127.0.0.1:6379> sadd k2 c d e f // 添加k2集合
(integer) 4
127.0.0.1:6379> sinter k1 k2 // k1 k2取交集
1) "d"
2) "c"
127.0.0.1:6379> sunion k1 k2 // k1 k2取并集
1) "b"
2) "a"
3) "f"
4) "e"
5) "d"
6) "c"
127.0.0.1:6379> sunionstore k1k2 k1 k2 // k1 k2去并集,并且存储在k1k2键中
(integer) 6
127.0.0.1:6379> smembers k1k2 // 取出键为k1k2的值
1) "b"
2) "a"
3) "f"
4) "e"
5) "d"
6) "c"
127.0.0.1:6379> sdiff k1 k2 // 取差集,从k1中取出k2没有的
1) "a"
2) "b"
127.0.0.1:6379> sdiff k2 k1 // 取差集,从k2中取出k1没有的
1) "f"
2) "e"

④排行榜,(zset有序集合)

127.0.0.1:6379> zadd key1 100 user1 80 user2 99 user3 10 user4 9 user5
(integer) 5
127.0.0.1:6379> zrange key1 0 -1 // 按分数从小到大排序
1) "user5"
2) "user4"
3) "user2"
4) "user3"
5) "user1"
127.0.0.1:6379> zrange key1 0 -1 withscores // 按分数从小到大排序,带上分数
 1) "user5"
 2) "9"
 3) "user4"
 4) "10"
 5) "user2"
 6) "80"
 7) "user3"
 8) "99"
 9) "user1"
10) "100"
127.0.0.1:6379> zrank key1 user1 // 取出user1的排名,第5名
(integer) 4
127.0.0.1:6379> zrank key1 user5 // 取出user5的排名,第1名
(integer) 0
127.0.0.1:6379> zscore key1 user5 // 取出user5的分数
"9"
127.0.0.1:6379> zrevrange key1 0 -1 // 按分数从大到小排序
1) "user1"
2) "user3"
3) "user2"
4) "user4"
5) "user5"
127.0.0.1:6379> zincrby key1 5 user2 // 给user2加上5分
"85"
127.0.0.1:6379> zrange key1 0 -1 withscores
 1) "user5"
 2) "9"
 3) "user4"
 4) "10"
 5) "user2"
 6) "85"
 7) "user3"
 8) "99"
 9) "user1"
10) "100"
127.0.0.1:6379> zincrby key1 -2 user2 // 给user2减2分
"83"

⑤点赞/收藏功能 (zset有序集合)

-- key:  love_user{userId}
-- score:当前时间戳,可按时间排序
-- value:  被点赞/收藏的id

如:用户id为1的用户,在不同时间段点赞了id为2,5,4的xx
127.0.0.1:6379> zAdd love_user1 1641190850 2
(integer) 1
127.0.0.1:6379> zAdd love_user1 1641196800 5
(integer) 1
127.0.0.1:6379> zAdd love_user1 1641283200 4
(integer) 1

判断是否已经点赞
127.0.0.1:6379> zScore love_user1 2
"1641190850"

按点赞时间倒序排列,取出10条
127.0.0.1:6379> zRevRangeByScore love_user1 1641283200 0 WITHSCORES LIMIT 0 10
1) "4"
2) "1641283200"
3) "5"
4) "1641196800"
5) "2"
6) "1641190850"

取消点赞
127.0.0.1:6379> zRem love_user1 5
(integer) 1

查看所有点赞的id
127.0.0.1:6379> zRange love_user1 0 -1
1) "2"
2) "4"

总的点赞数
127.0.0.1:6379> zCard love_user1
(integer) 2

未完待续.......

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 158,117评论 4 360
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 66,963评论 1 290
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 107,897评论 0 240
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,805评论 0 203
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,208评论 3 286
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,535评论 1 216
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,797评论 2 311
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,493评论 0 197
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,215评论 1 241
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,477评论 2 244
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 31,988评论 1 258
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,325评论 2 252
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 32,971评论 3 235
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,055评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,807评论 0 194
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,544评论 2 271
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,455评论 2 266