Redis的使用--基本数据类型的操作命令和应用场景

本文涉及的产品
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
云数据库 Tair(兼容Redis),内存型 2GB
简介: Redis的使用--基本数据类型的操作命令和应用场景

Redis的基本数据类型

最基本的数据类型strings

最基本也是最常用的数据类型就是String,对应的操作命令也比较简单的,有get/set/del等;它的对应的值可以是任何种类的字符串,最大保存长度512MB。基本命令的使用如下:

set name echo
get name
del name

set key 1
incr key
decr key
incrby key 20
decrby key 20
incrbyfloat key 2.1

set name ab
append name c
getrange name 1 5
strlen name
mget name1 name2 name3
mset name4 echo4 name5 echo5 name6 echo6

在这里插入图片描述

字符串中一个特殊操作setnx

setnx name echo
如果name存在就返回0存入不成功,如果name不存在就返回1存入成功。
基于该特性我们可以用它来实现分布式锁。但是注意:使用改特性也有一个缺点就是,可能会造成死锁。如果我们在使用过程当中,使用del key释放锁,有可能会释放锁失败,导致其他操作永远获取不到锁。当让我们也可以对ke设置过期时间,但是也会有相同的问题。解决方案:

数据类型list

对于该数据类型,我觉得用list一点也不贴切,应该叫做:有序的队列,才合适。毕竟list是无序的,而且也没有先后一说。基本操作命令如下:

lpush queue a
lpush queue b c
rpush queue d e
lpop queue
rpop queue
lindex queue 0
lrange queue 0 -1
ltrim queue 0 3
del queue
llen queue
brpop queue 50

在这里插入图片描述

list数据结构中brpop是一个高级操作

brpop queue 60 
如果queue队列中存在元素,直接弹出最右边的按个元素,如果不存在,轮询等待60s。超时,直接返回null。
该数据结构有一个明显的特点,那就是有序,不管是从左边存入还是右边存入,都能够有效的实现队列的进出。我们可以看到最后一个条命令,它其实是redis提供的一个高级操作,利用list队列的特性,实现了阻塞式访问,我们可以使用该功能做一个简单的发布订阅功能。如果存入数据作为发布消息,使用brpop阻塞式访问来订阅。

数据类型set

Redis中Set 是 String 类型的无序集合。该集合有set集合的属性,元素唯一, 所以对应的redis set数据成员是唯一的,这就意味着集合中不能出现重复的数据。

sadd myset a b c d e f g
smembers myset
scard myset
srandmember key
spop myset
srem myset d e f
sismember myset a
sdiff set1 set2
sinter set1 set2
sunion set1 set2

在这里插入图片描述

在set中,元素都不是重复的,所以我们可以用它来记录一些唯一的值。这几个基本的命令里面我们可以看到有一个spop myset 随机弹出一个元素,利用set的唯一性,和随机弹出元素的特性,我们可以使用set集合实现一个抽奖活动。将所有人的id存入set集合中,然后使用spop随机弹出元素,弹出的元素id就是中奖人。

Redis的zset -- 有序集合

zset和Set类型极为相似,它们都是字符串的集合,都不允许重复的成员出现在一个Set中。它和set集合的区别只去在于zset是有序的,set是无序的。而且set的存储和zset的存储不一样

zadd myzset 10 java 20 php 30 ruby 40 cpp 50 python
zrange myzset 0 -1 withscores
zrevrange myzset 0 -1 withscores
zrangebyscore myzset 20 30
zrem myzset php cpp
zcard myzset
zincrby myzset 5 python
zcount myzset 20 60
zrank myzset java
zscore myzset java

在这里插入图片描述

zset是一个有序的集合,它的排序是根据score来进行的,所以我们可以使用该特性来实现一个最热文章的功能,当文章的热度上涨之后,我们对文章对应score来进行递增即可。

Redis的数据类型Hash

Redis的哈希数据类型存储的是一个string类型的field和value的映射表,hash适合存放对象

hset h1 f 6
hmset h1 a 1 b 2 c 3 d 4
hget h1 a
hmget h1 a b c d
hkeys h1
hvals h1
hgetall h1
hexists h1 f
hdel h1 f
hlen h1

在这里插入图片描述

hash的操作和我们java开发中操作map很类似,比如添加一个key为h1、field为f、value为6的hash值,在java中就相当于创建一个名字为h1的map,存入key为f,value为6的键值对。该数据结构的特点很适合我们在业务中存放对象,比如使用他来实现购物车。将hash设计成为后面这种模式即可:key:用户 id;field:商品 id;value:商品数量。商品在购物车中的数据量使用如下命令来实现即可
对我们的hash值来进行加1
hincrby h1 d 1

对我们的hash值来进行减1
hincrby h1 d -1
相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore     ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库 ECS 实例和一台目标数据库 RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
目录
相关文章
|
3月前
|
NoSQL 安全 测试技术
Redis游戏积分排行榜项目中通义灵码的应用实战
Redis游戏积分排行榜项目中通义灵码的应用实战
89 4
|
2月前
|
存储 缓存 NoSQL
解决Redis缓存数据类型丢失问题
解决Redis缓存数据类型丢失问题
180 85
|
13天前
|
缓存 NoSQL 架构师
Redis批量查询的四种技巧,应对高并发场景的利器!
在高并发场景下,巧妙地利用缓存批量查询技巧能够显著提高系统性能。 在笔者看来,熟练掌握细粒度的缓存使用是每位架构师必备的技能。因此,在本文中,我们将深入探讨 Redis 中批量查询的一些技巧,希望能够给你带来一些启发。
68 23
Redis批量查询的四种技巧,应对高并发场景的利器!
|
13天前
|
缓存 NoSQL JavaScript
Vue.js应用结合Redis数据库:实践与优化
将Vue.js应用与Redis结合,可以实现高效的数据管理和快速响应的用户体验。通过合理的实践步骤和优化策略,可以充分发挥两者的优势,提高应用的性能和可靠性。希望本文能为您在实际开发中提供有价值的参考。
43 11
|
2月前
|
存储 NoSQL Redis
redis常见数据类型
Redis 是一种基于内存的键值存储数据库,支持字符串、哈希表、列表、集合及有序集合等多种数据类型,每种类型均有特定用途与适用场景,提供丰富的命令操作,适用于高速数据访问与处理。
56 5
|
3月前
|
NoSQL Java 数据处理
基于Redis海量数据场景分布式ID架构实践
【11月更文挑战第30天】在现代分布式系统中,生成全局唯一的ID是一个常见且重要的需求。在微服务架构中,各个服务可能需要生成唯一标识符,如用户ID、订单ID等。传统的自增ID已经无法满足在集群环境下保持唯一性的要求,而分布式ID解决方案能够确保即使在多个实例间也能生成全局唯一的标识符。本文将深入探讨如何利用Redis实现分布式ID生成,并通过Java语言展示多个示例,同时分析每个实践方案的优缺点。
95 8
|
3月前
|
监控 NoSQL 网络协议
【Azure Redis】部署在AKS中的应用,连接Redis高频率出现timeout问题
查看Redis状态,没有任何异常,服务没有更新,Service Load, CPU, Memory, Connect等指标均正常。在排除Redis端问题后,转向了AKS中。 开始调查AKS的网络状态。最终发现每次Redis客户端出现超时问题时,几乎都对应了AKS NAT Gateway的更新事件,而Redis服务端没有任何异常。因此,超时问题很可能是由于NAT Gateway更新事件导致TCP连接被重置。
|
3月前
|
缓存 NoSQL PHP
Redis作为PHP缓存解决方案的优势、实现方式及注意事项。Redis凭借其高性能、丰富的数据结构、数据持久化和分布式支持等特点,在提升应用响应速度和处理能力方面表现突出
本文深入探讨了Redis作为PHP缓存解决方案的优势、实现方式及注意事项。Redis凭借其高性能、丰富的数据结构、数据持久化和分布式支持等特点,在提升应用响应速度和处理能力方面表现突出。文章还介绍了Redis在页面缓存、数据缓存和会话缓存等应用场景中的使用,并强调了缓存数据一致性、过期时间设置、容量控制和安全问题的重要性。
60 5
|
3月前
|
存储 消息中间件 NoSQL
使用Java操作Redis数据类型的详解指南
通过使用Jedis库,可以在Java中方便地操作Redis的各种数据类型。本文详细介绍了字符串、哈希、列表、集合和有序集合的基本操作及其对应的Java实现。这些示例展示了如何使用Java与Redis进行交互,为开发高效的Redis客户端应用程序提供了基础。希望本文的指南能帮助您更好地理解和使用Redis,提升应用程序的性能和可靠性。
56 1
|
17天前
|
存储 缓存 NoSQL
云端问道21期方案教学-应对高并发,利用云数据库 Tair(兼容 Redis®*)缓存实现极速响应
云端问道21期方案教学-应对高并发,利用云数据库 Tair(兼容 Redis®*)缓存实现极速响应