redis五种数据类型及使用场景

一、Redis简介

Redis 是一个开源的使用 C 语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value 数据库。它可以用作数据库、缓存和消息中间件。

二、Redis的数据类型 

Redis 是一种高级的 key-value 的存储系统,其中key值是二进制安全的,这意味着可以用任何二进制序列作为key值,从形如”foo”的简单字符串到一个JPEG文件的内容都可以。空字符串也是有效key值。而Redis的 value 支持五种数据类型,分别为string (字符串类型),hash (表类型),list (列表类型),set(集合类型) 和zset (有序集合类型)。

String(字符串)类型在 Redis 中以二进制保存,没有编码和解码的过程。无论存入的是字符串、整数、浮点类型都会以字符串写入redis中,所有的key都是字符串类型,其它几种数据类型构成的元素也是字符串。字符串的长度不能超过512M。 常用命令: set,get,decr,incr,mget 等。

1.String (字符串)

应用场景:普通的key/ value 存储都可以归为此类.即可以完全实现目前 Memcached 的功能,并且效率更高。还可以享受Redis的定时持久化,操作日志及 Replication ,常规计数:微博数,粉丝数等等功能。

2.Hash (表类型) key是一个字符串类型,value是一个键值对集合,每一个 Hash 可以存储 40 亿个键值对。 常用命令: hget,hset,hgetall 等。

应用场景:该类型非常适合于存储对象的信息。如一个用户有姓名,密码,年龄等信息。

3.List (列表类型)按插入顺序排序。您可以向Redis列表的头部或尾部添加元素。在插入时,如果该键并不存在,Redis 将为该键创建一个新的链表,如果这个键已经存在,则是向 list 添加元素。与此相反,如果链表中所有的元素均被移除,那么该键也将会被从数据库中删除。List 中可以包含的最大元素数量是 40 亿个。 常用命令:lpush,rpush,lpop,rpop,lrange,BLPOP(阻塞版)等。

应用场景:1.最新消息排行。2.消息队列,可以利用Lists的PUSH操作,将任务存在Lists中,然后工作线程再用POP操作将任务取出进行执行。

4.set(集合类型)String 类型的无序集合。集合成员是唯一的,不能出现重复的数据。Redis 中集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是 O(1)。集合中最大的成员数为 232 - 1 (4294967295, 每个集合可存储40多亿个成员)。 常用操作:sadd,spop,smembers,sunion 等。

应用场景: 当你需要存储一个列表数据,又不希望出现重复数据时,set是一个很好的选择,并且set提供了判断某个成员是否在一个set集合内的重要接口,这个也是list所不能提供的。比如在微博应用中,可以将一个用户所有的关注人存在一个集合中,将其所有粉丝存在一个集合。Redis还为集合提供了求交集、并集、差集等操作,可以非常方便的实现如共同关注、共同喜好、二度好友等功能,对上面的所有集合操作,你还可以使用不同的命令选择将结果返回给客户端还是存集到一个新的集合中。

5.zset (有序集合类型) Redis 有序集合和集合一样也是string类型元素的集合,且不允许重复的成员。不同的是每个元素都会关联一个double类型的分数。redis正是通过分数来为集合中的成员进行从小到大的排序。有序集合的成员是唯一的,但分数(score)却可以重复。集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是O(1)。 集合中最大的成员数为 232 - 1 (4294967295, 每个集合可存储40多亿个成员)。 常用命令:zadd,zrange,zrem,zcard等

应用场景:Redis sorted set的使用场景与set类似,区别是set不是自动有序的,而sorted set可以通过用户额外提供一个优先级(score)的参数来为成员排序,并且是插入有序的,即自动排序。当你需要一个有序的并且不重复的集合列表,那么可以选择sorted set数据结构,比如twitter 的public timeline可以以发表时间作为score来存储,这样获取时就是自动按时间排好序的。 另外还可以用Sorted Sets来做带权重的队列,比如普通消息的score为1,重要消息的score为2,然后工作线程可以选择按score的倒序来获取工作任务。让重要的任务优先执行。(1.去重排序 2.优先级队列)