redis实际应用实现合集

一、redis实现抢红包的功能(set 数据结构)

分两种情况:

情况一:

从10个观众中随机抽2名幸运观众

首先需要把10个观众的id(具体是什么id可以根据实际业务情况自己定义)放到redis 的 set 集合里

然后随机抽取2名幸运观众,具体redis命令:

java 复制代码
127.0.0.1:6379> sadd act:002 0001
(integer) 1
127.0.0.1:6379> sadd act:002 0002
(integer) 1
127.0.0.1:6379> sadd act:002 0003
(integer) 1
127.0.0.1:6379> sadd act:002 0004
(integer) 1
127.0.0.1:6379> sadd act:002 0005
(integer) 1
127.0.0.1:6379> sadd act:002 0006
(integer) 1
127.0.0.1:6379> sadd act:002 0007
(integer) 1
127.0.0.1:6379> sadd act:002 0008
(integer) 1
127.0.0.1:6379> sadd act:002 0009
(integer) 1
127.0.0.1:6379> sadd act:002 0000
(integer) 1

插入10个观众,act:002是活动的名字,后面分别是观众id

查看观众:

java 复制代码
127.0.0.1:6379> SMEMBERS act:002
 1) "0007"
 2) "0005"
 3) "0006"
 4) "0008"
 5) "0003"
 6) "0004"
 7) "0002"
 8) "0000"
 9) "0009"
10) "0001"

插入成功

随机抽取2名幸运观众:

java 复制代码
127.0.0.1:6379> SRANDMEMBER act:002 2
1) "0001"
2) "0002"

情况二:

从10名观众中抽取奖项,其中一等奖1人,二等奖2人,三等奖3人

需要用到redis的 SPOP命令

java 复制代码
127.0.0.1:6379> spop act:002 1 #抽取一等奖 1 人
1) "0001"
127.0.0.1:6379> SMEMBERS act:002
1) "0002"
2) "0005"
3) "0007"
4) "0006"
5) "0000"
6) "0009"
7) "0003"
8) "0008"
9) "0004"
127.0.0.1:6379> spop act:002 2 #抽取二等奖 2 人
1) "0006"
2) "0005"
127.0.0.1:6379> SMEMBERS act:002
1) "0002"
2) "0007"
3) "0000"
4) "0009"
5) "0003"
6) "0008"
7) "0004"
127.0.0.1:6379> spop act:002 3 #抽取三等奖 3 人
1) "0004"
2) "0000"
3) "0003"
127.0.0.1:6379> SMEMBERS act:002
1) "0002"
2) "0007"
3) "0009"
4) "0008"
相关推荐
共享家95273 分钟前
基于 Coze 工作流搭建历史主题图片生成器
前端·人工智能·js
zhaoyin19945 分钟前
fiddler抓包工具使用
前端·测试工具·fiddler
微祎_6 分钟前
Flutter for OpenHarmony:构建一个 Flutter 单词拼图游戏,深入解析状态驱动 UI、交互式字母操作与教育类应用设计
javascript·flutter·ui
摘星编程18 分钟前
用React Native开发OpenHarmony应用:ProgressBar缓冲进度显示
javascript·react native·react.js
人机与认知实验室19 分钟前
<span class=“js_title_inner“>如何看待特斯拉第三代Optimus机器人?</span>
开发语言·javascript·机器人·ecmascript·unix
Doris89323 分钟前
【 Vue】 Vue3全面讲解文档
前端·javascript·vue.js
换日线°23 分钟前
vue 实现Element Plus的炫酷主题切换
javascript·vue.js
linweidong30 分钟前
大厂工程化实践:如何构建可运维、高稳定性的 Flutter 混合体系
javascript·flutter
Hexene...33 分钟前
【前端Vue】如何快速直观地查看引入的前端依赖?名称版本、仓库地址、开源协议、作者、依赖介绍、关系树...(Node Modules Inspector)
前端·javascript·vue.js
fanruitian35 分钟前
div水平垂直居中
前端·javascript·html