Redis的10大数据类型

 string(字符串

一个key对应一个value
stirng类型是二进制安全的(支持序列化),意思是redis的string可以包含任何数据,比如jpg图片或者序列化对象
string类型是reids最基本的数据类型,一个reids中字符串value最多可以是512M

 list(列表)


redis列表是简单的字符串列表,按照出入顺序排序。你可以添加一个元素倒列表头部(左边)或者尾部(右边)
它的底层实际是个双端链表,最多可以包含2^32-1个元素(4294967295,每个列表超过40亿个元素)

hash(哈希表)


hash是一个string类型的field(字段) 和 value(值)的映射表,hash特别适合用于存储对象。
redis中每个hash可以存储2^32-1键值对(40多亿)

set(集合)


reids的set是string类型的无序集合。集合成员是唯一的,这意味着集合中不能出现重复的数据,集合对象的编码可以是intset或者hashtable。
redis中set集合是通过哈希表实现的,所以添加、删除、查找的复杂度是O(1)。
集合中最大的成员数为2^32-1(4294967295,每个集合可存储40多亿个成员)

zset(有序集合)


reids zset和set一样也是string类型元素的集合,且不允许重复的成员。
不同的是每个元素都会关联一个double类型的分数,reids正是通过分数来为集合中的成员进行从小到大的排序
zset的成员是唯一的,但是分数(score)却可以重复
zset集合是通过哈希表来实现的,所以添加、删除、查找的复杂度都是O(1)。集合中对的成员数为2^32-1

GEO(地理空间)


主要存储磁力位置信息,并对存储的信息进行操作,包括
添加地理位置的坐标。
获取地理位置的坐标。
计算两个位置之见的距离。
根据用户给定的经纬度坐标来获取指定范围内的地理位置集合

HypperLogLog(基数统计)


HypperLogLog是用来做基数统计的算法,hyperLogLog的优点是,在输入元素的数量或者体积非常非常大时,计算基数所需的空间总时固定且是最小的。
(比如说,某东,某猫计算每天有多少人访问,这样的话数据量很大,这样就可以用hyperLogLog来统计基数)
在redis里面,每个HypperLogLog健只需要花费12B内存,就可以计算接近2^64个不同元素的基数。这和计算基数时,元素越多耗费内存就越多的集合形成鲜明对比。
但是,因为HypperLogLog只会根据输入元素来计算基数,而不会对储存输入元素本身,所以HypperLogLog不能像集合那样,返回输入的各个元素。

bitmap(位图)


一个字节(一个byte)= 8位
01010101
比如签到是0未签到是1  只记录0或1就好

bitfield(位域)


通过bitfield命令可以一次性操作多个比特位域(指的是连续的多个比特位),它会执行一系列操作并返回一个响应数组,这个数组中的元素对应参数列表中的相应操作的执行结果。
说白了就是通过bitfield命令我们可以一次性对多个比特位域进行操作。

stream(流)


是redis5.0以后新增的数据结构。
redis stream主要用于消息队列(MQ,Message Queue),redis本身是有一个redis发布订阅(pub/sub)来实现消息队列的功能,但它有个缺点就是消息无法持久化,如果网络断开,或者reids宕机等,消息就会被丢失。
简单类说发布订阅(pub/sub)可以分发消息,但无法记录历史
而reids stream提供了消息的持久化和主备复制功能,可以让任何客户端访问任何时刻的数据,并且能记住每一个客户端的访问位置,还能保证消息不回丢失。

  • 8
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值