十年网站开发经验 + 多家企业客户 + 靠谱的建站团队
量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决
创新互联www.cdcxhl.cn八线动态BGP香港云服务器提供商,新人活动买多久送多久,划算不套路!
创新互联是一家专业提供青神企业网站建设,专注与成都网站制作、做网站、H5响应式网站、小程序制作等业务。10年已为青神众多企业、政府机构等服务。创新互联专业网站制作公司优惠进行中。Redis的五种基本数据类型是什么?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。
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 中是使用 跳表 来实现的,我们知道只有数组这种连续的空间才能使用二分查找进行快速的定位,而链表是不可以的。跳表帮助链表查找的时候节省了很多时间(使用跳的方式来遍历索引来进行有序插入)。
看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注创新互联-成都网站建设公司行业资讯频道,感谢您对创新互联的支持。