用了这么久redis你了解几种redis数据类型

41次阅读

共计 1759 个字符,预计需要花费 5 分钟才能阅读完成。

简单介绍一下 redis 的几种数据类型:StringsListsSetsHasheSorted setsBitmaps and HyperLogLogs

Strings

Strings 是 redis 的最基础的类型,意味着 reds stings 可以包含任何数据类型,普通的 string,integer…自不必说,JPEG 图片,Java 对象,文件等等都可以序列化成 strings。

最大限制:512M

常用操作:

  • INCR, DECR, INCRBY:通过 strings 实现原子化操作
  • APPEND:改变字符串
  • GETRANGE , SETRANGE:自由获取或者变更 Strings
  • GETBIT, SETBIT:对 Strings 进行位操作,如通过 redis 创建一个 bloom filter

其他:available string commands

Lists

Redis Lists 是 strings 的集合 list,顺序为元素的插入顺序。当然也可以通过命令在 head 或者 tail 插入元素。即使 list 很大,在 head 或者 tail 增删元素的速度也很快,但是如果操作中间的元素,则复杂度为 O(N)。

lists 最大长度:2^32 – 1 (4294967295,也就是每个 list 可以存 40 亿个元素)

有意思的案例:

  • 创建设计网络中的时间线,使用 LPUSH 增加元素,而使用 LRANGE 获取最新插入的几个元素
  • 使用 LPUSH 和 LTRIM 创建一个固定容量的 list,只记录最新的几个元素
  • 使用 list 结构创建一个消息队列,如 ruby 的 Resque – 用于创建后台任务
  • BLPOP

其他:available commands operating on lists

Sets

Redis Sets 是 strings 的无序无重复集合。增删查的复杂度是 0(1),基于 sets 可以做 unions, intersections 等操作

sets 最大长度:2^32 – 1 (4294967295,也就是每个 set 可以存 40 亿个元素)

一些案例:

  • trace 一些唯一事件,比如说记录一篇 blog 的访问 ip,仅仅只需要使用 SADD,而不需要考虑是否重复。
  • 创建一个标签系统,给对象标记不同的 tag
  • 使用 SPOP 或者 SRANDMEMBER 命令从一个 set 中随机抽取元素
  • 其他:full list of Set commands

Hashes

Redis Hashes 是用来存储一些键值对的,举个栗子:

@cli
HMSET user:1000 username antirez password P1pp0 age 34
HGETALL user:1000
HSET user:1000 password 12345
HGETALL user:1000

每一个 hash 都可以存储至多 2^32 – 1 个 键值对

其他:full list of Hash commands

Sorted sets

redis Sorted Sets 和 sets 类型相似,但最大的不同点是 Sorted Set 的每一个元素都有一个分值,这个分值可以用作排序,虽然元素是不重复的,但分值可能相同。可以获取不同分值段内的一些元素。

sorted sets 可以做很多有意思的事情,与直接操作数据库相比,有很好的性能

  • 比如设计一个在线游戏的选手积分榜,使用 ZADD 来增加一个新的记录,使用 ZRANGE 获取前几名的选手,也可以使用 ZRANGE 来获取一个选手的排名。使用 ZRANK 和 ZRANGE 可以吃很快查询到一个元素附近的几个元素
  • Sorted Sets 常常被用来做作 redis 中的索引数据,比如有很多用户的 hash 数据,可以使用用户的年龄作为分值,用户 id 作为值,使用 ZRANGEBYSCORE 就可以吃很快查询出一个年龄区间内的用户

其他:full list of Sorted Set commands

Bitmaps and HyperLogLogs

Redis 同时也支持 Bitmaps 和 HyperLogLogs,基于 Strings 实现,但有他们自己的语义。

其他:introduction to Redis data types

推荐的 redisdocs:

  • http://doc.redisfans.com/
  • http://redisdoc.com/

本文由 歧途老农 创作,采用 CC BY 4.0 CN 协议 进行许可。可自由转载、引用,但需署名作者且注明文章出处。如转载至微信公众号,请在文末添加作者公众号二维码。

正文完
 0