Redis作为缓存具有极其丰富的功能,比如计数器、好友关系以及排行榜等等。而Redis之所能够实现如此强大的功能,完全是依赖着它的基本数据结构。今天我们来看看Redis的五种基本的数据结构,分别是字符串(strings), 散列(hashes), 列表(lists), 集合(sets)以及有序集合(zset)。
1、字符串(strings)
绝大部分编程语言中都少不了的基本数据类型就是字符串(strings),数据库Redis也不例外。下面我们来看一下关于字符串的基本操作:
set key value设置值
get key获取某个key的值
mset key1 value1 key2 value2批量设置并且是原子的,可以用来减少网络时间消耗
mget key1 key2批量获取并且是原子的,可以用来减少网络时间消耗
incr key自增指定key的值
decr key自减指定key的值
incrby key value自增指定数值
decrby key value自减指定数值
incrbyfloat key floatvalue增加指定浮点数,前面几个操作就可以用来实现计数器的功能。
setnx key value如果不存在该key则可以设置成功,否则会失败,加上过期时间限制,则是redis实现分布式锁的一种方式(后面会提到)。
set key value xx与前面相反,如果存在则设置成功,否则失败(相当于更新操作)
2、散列(hashes)
我们可以把hash理解为小型Redis,Redis在底层实现上和Java中的HashMap差不多,都是使用数组+链表的二维结构实现的。不一样的是,在Redis中字典的值只能是字符串,而且他们rehash的方式也不同,在Redis中使用的是渐进式rehash。
hset key field value设置字典中某个key的值
hsetnx key field value设置字典中某个key的值(不存在的)
hmset key field1 value1 field2 value2… 批量设置
hget key field获取字典中某个key的值
hmget key field1 field2批量获取
hgetall key获取全部
hdel key field删除某个key
hexists key field判断是否存在
hlen key获取指定key对应的字典中的存储个数
hvals key返回所有的value
hkeys key返回所有的key
hincrby key field increValue增加某个value的值(也可以增加负数)
hincrbyfloat key field floatValue增加某个value的值(浮点数)
3、列表(lists)
Redis中的列表相当于Java中的LinkedList,也就是底层是通过链表来实现的,所以对于list来说插入删除操作很快,但索引定位非常慢。Redis提供了许多对于list的操作,如出入等操作,你可以充分利用它们来实现一个栈或者队列。
lpush key item1 item2 item3… 从左入栈
rpush key item1 item2 item3… 从右入栈
lpop key从左出栈
rpop key从右出栈
lindex key index获取指定索引的元素O(n)谨慎使用
lrange key start end获取指定范围的元素O(n)谨慎使用
linsert key before|after item newitem在指定元素的前面或者后面添加新元素
lrem key count value删除指定个数值为value的元素
count = 0 :删除所有值为value的元素
count > 0 :从左到右删除count个值为value的元素
count < 0 :从右到做删除|count|个值为value的元素
ltrim key start end保留指定范围的元素
lset key index newValue更新某个索引的值
blpop key timeout没有则阻塞(timeout指定阻塞时间 为0代表永久)
brpop key timeout没有则阻塞(timeout指定阻塞时间 为0代表永久)这两个可以用来实现消费者生产者
4、集合(sets)
Redis中的set相当于Java中的HashSet(无序集合),其中里面的元素不可以重复,我们可以利用它实现一些去重的功能。我们还有对几个集合进行取交集,取并集等操作,这些操作就可以获取不同用户之间的共同好友、共同爱好等等。
sadd key value添加元素
sdel key value删除某个元素
sismember key value判断是否是集合中的元素
srandmember key count随机获取指定个数的元素(不会影响集合结构)
spop key count从集合中随机弹出元素(会破坏结合结构)
smembers key获取集合所有元素O(n)复杂度
scard key获取集合个数
sinter set1 set2… 获取所有集合中的交集
sdiff set1 set2… 获取所有集合中的差集
sunion set1 set2… 获取所有集合中的并集
5、有序集合(zset)
Redis中的zset是一个有序集合,通过它可以实现很多有意思的功能,比如学生成绩排行榜,视频播放量排行榜等等。zset中是使用 跳表 来实现的,我们知道只有数组这种连续的空间才能使用二分查找进行快速的定位,而链表是不可以的。跳表帮助链表查找的时候节省了很多时间(使用跳的方式来遍历索引来进行有序插入)。
以上就是Redis的五种基本数据类型介绍,大家都看懂了吗?如果想学习更多关于Redis的内容,可以阅读以往的相关资讯,博学谷更有海量的在线学习视频等着你~