博客
关于我
Redis的常用数据结构
阅读量:325 次
发布时间:2019-03-04

本文共 1460 字,大约阅读时间需要 4 分钟。

Redis的常用数据结构

1.string

  1. string 数据结构是简单的 key-value 类型
  2. 常用命令: set,get,strlen,exists,dect,incr,setex
  3. 应用场景 :常用在需要计数的场景,比如用户的访问次数、热点文章的点赞转发数量

2.list

  1. list 是双向链表,易于插入删除,但是随机访问比较困难

  2. 常用命令: rpush,lpop,lpush,rpop,lrange、llen

    在这里插入图片描述

  3. 应用场景: 发布与订阅或者说消息队列、慢查询

3.hash

  1. hash的内部是现实 数组+链表,特别适合用于存储对象

  2. 常用命令: hset,hmset,hexists,hget,hgetall,hkeys,hvals 等

    在这里插入图片描述

  3. 应用场景: 系统中对象数据的存储

4.set

  1. Redis 中的 set 类型是一种无序,不重复集合,可以非常方便的判断某个成员是否在一个 set 集合内,可以基于 set 轻易实现交集、并集、差集的操作,
  2. 常用命令: sadd,spop,smembers,sismember,scard,sinterstore,sunion 等
127.0.0.1:6379> sadd mySet value1 value2 # 添加元素进去(integer) 2127.0.0.1:6379> sadd mySet value1 # 不允许有重复元素(integer) 0127.0.0.1:6379> smembers mySet # 查看 set 中所有的元素1) "value1"2) "value2"127.0.0.1:6379> scard mySet # 查看 set 的长度(integer) 2127.0.0.1:6379> sismember mySet value1 # 检查某个元素是否存在set 中,只能接收单个元素(integer) 1127.0.0.1:6379> sadd mySet2 value2 value3(integer) 2127.0.0.1:6379> sinterstore mySet3 mySet mySet2 # 获取 mySet 和 mySet2 的交集并存放在 mySet3 中(integer) 1127.0.0.1:6379> smembers mySet31) "value2"
  1. 应用场景: 需要存放的数据不能重复以及需要获取多个数据源交集和并集等场景:比如实现如共同关注、共同粉丝、共同喜好等功能

5.sorted set

  1. sorted set可以看作是有序的set,因为它在set的基础上引入了一个权重参数 score,可以根据这个参数来排序,和确定范围
  2. 常用命令: zadd,zcard,zscore,zrange,zrevrange,zrem 等
zadd myZset 2.0 value2 1.0 value3
  1. 应用场景: 需要对数据根据某个权重进行排序的场景,比如各种排行榜

6.bitMap

  1. 介绍 : bitmap 存储的是连续的二进制数字(0 和 1),通过 bitmap, 只需要一个 bit 位来表示某个元素对应的值或者状态,key 就是对应元素本身 。我们知道 8 个 bit 可以组成一个 byte,所以 bitmap 本身会极大的节省储存空间。
  2. 常用命令: setbit 、getbit 、bitcount、bitop
  3. 应用场景: 户签到情况、活跃用户情况等

画了个图帮助理解

在这里插入图片描述

在这里插入图片描述

PS:有错误欢迎留言指正

转载地址:http://vfmq.baihongyu.com/

你可能感兴趣的文章
Mysql学习总结(6)——MySql之ALTER命令用法详细解读
查看>>
Mysql学习总结(70)——MySQL 优化实施方案
查看>>
Mysql学习总结(71)——MySQL 重复记录查询与删除总结
查看>>
Mysql学习总结(73)——MySQL 查询A表存在B表不存在的数据SQL总结
查看>>
Mysql学习总结(77)——温故Mysql数据库开发核心原则与规范
查看>>
Mysql学习总结(78)——MySQL各版本差异整理
查看>>
Mysql学习总结(79)——MySQL常用函数总结
查看>>
Mysql学习总结(7)——MySql索引原理与使用大全
查看>>
Mysql学习总结(80)——统计数据库的总记录数和库中各个表的数据量
查看>>
Mysql学习总结(81)——为什么MySQL不推荐使用uuid或者雪花id作为主键?
查看>>
Mysql学习总结(82)——MySQL逻辑删除与数据库唯一性约束如何解决?
查看>>
Mysql学习总结(83)——常用的几种分布式锁:ZK分布式锁、Redis分布式锁、数据库分布式锁、基于JDK的分布式锁方案对比总结
查看>>
Mysql学习总结(84)—— Mysql的主从复制延迟问题总结
查看>>
Mysql学习总结(85)——开发人员最应该明白的数据库设计原则
查看>>
MySQL学习笔记十七:复制特性
查看>>
mysql安装卡在最后一步解决方案(附带万能安装方案)
查看>>
mysql安装和启动命令小结
查看>>
MySQL安装配置教程(非常详细),从零基础入门到精通,看完这一篇就够了
查看>>
mysql安装配置简介
查看>>
MySQL定义和变量赋值
查看>>