美文网首页
Redis类型及使用场景总结

Redis类型及使用场景总结

作者: 皮蛋馅儿 | 来源:发表于2020-04-17 21:34 被阅读0次

    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"
    

    未完待续.......

    相关文章

      网友评论

          本文标题:Redis类型及使用场景总结

          本文链接:https://www.haomeiwen.com/subject/bajpmhtx.html