博客
关于我
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 取表中分组之后最新一条数据 分组最新数据 分组取最新数据 分组数据 获取每个分类的最新数据
查看>>
mysql 四种存储引擎
查看>>
MySQL 基础模块的面试题总结
查看>>
MySQL 备份 Xtrabackup
查看>>
mysql 多个表关联查询查询时间长的问题
查看>>
mySQL 多个表求多个count
查看>>
mysql 多字段删除重复数据,保留最小id数据
查看>>
MySQL 多表联合查询:UNION 和 JOIN 分析
查看>>
MySQL 大数据量快速插入方法和语句优化
查看>>
mysql 如何给SQL添加索引
查看>>
mysql 字段区分大小写
查看>>
mysql 字段合并问题(group_concat)
查看>>
mysql 字段类型类型
查看>>
MySQL 字符串截取函数,字段截取,字符串截取
查看>>
MySQL 存储引擎
查看>>
mysql 存储过程 注入_mysql 视图 事务 存储过程 SQL注入
查看>>
MySQL 存储过程参数:in、out、inout
查看>>
mysql 存储过程每隔一段时间执行一次
查看>>
mysql 存在update不存在insert
查看>>
Mysql 学习总结(86)—— Mysql 的 JSON 数据类型正确使用姿势
查看>>