共计 1759 个字符,预计需要花费 5 分钟才能阅读完成。
简单介绍一下 redis 的几种数据类型:Strings,Lists,Sets,Hashe,Sorted sets,Bitmaps 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 协议 进行许可。可自由转载、引用,但需署名作者且注明文章出处。如转载至微信公众号,请在文末添加作者公众号二维码。