博客
关于我
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当查询的时候有多个结果,但需要返回一条的情况用GROUP_CONCAT拼接
查看>>
MySQL必知必会(组合Where子句,Not和In操作符)
查看>>
MySQL必知必会总结笔记
查看>>
MySQL快速入门
查看>>
MySQL快速入门——库的操作
查看>>
mysql快速复制一张表的内容,并添加新内容到另一张表中
查看>>
mysql快速查询表的结构和注释,字段等信息
查看>>
mysql怎么删除临时表里的数据_MySQL中关于临时表的一些基本使用方法
查看>>
mysql性能优化
查看>>
MySQL性能优化必备25条
查看>>
Mysql性能优化(1):SQL的执行过程
查看>>
Mysql性能优化(2):数据库索引
查看>>
Mysql性能优化(3):分析执行计划
查看>>
Mysql性能优化(4):优化的注意事项
查看>>
Mysql性能优化(6):读写分离
查看>>
MySQL性能测试及调优中的死锁处理方法
查看>>
mysql性能测试工具选择 mysql软件测试
查看>>
mysql恢复root密码
查看>>
Mysql悲观锁
查看>>