奖池渲染以及中奖逻辑

┌──────────────────────────────────────────┐

│ T1: 用户打开页面 │

└──────────────┬───────────────────────────┘

┌──────────────────────────────────────────┐

│ 后端: 确定用户所属的主奖池 │

│ getPrizePoolSeqNumber(mobile) │

│ 例如: 返回 "3" (5次以下奖池) │

└──────────────┬───────────────────────────┘

┌──────────────────────────────────────────┐

│ 后端: 同时获取主奖池和备用奖池 │

│ 主奖池ID: "3" │

│ 备用奖池ID: "3_backup" (通过映射获取) │

└──────────────┬───────────────────────────┘

┌──────────────────────────────────────────┐

│ 后端: 遍历主奖池的每个奖品 │

│ 对每个奖品进行检查: │

│ │

│ 奖品A: 库存=0 ❌ → 用备用奖池的A'替换 ✅ │

│ 奖品B: 库存=100 ✅ → 直接使用 │

│ 奖品C: 已达上限 ❌ → 用备用奖池的C'替换 ✅│

│ 奖品D: 非POP客群 ❌ → 用备用奖池的D'替换 ✅│

│ 奖品E: 库存=50 ✅ → 直接使用 │

└──────────────┬───────────────────────────┘

┌──────────────────────────────────────────┐

│ 后端: 返回混合后的奖品列表给前端 │

A', B, C', D', E

│ (部分来自主奖池,部分来自备用奖池) │

└──────────────┬───────────────────────────┘

┌──────────────────────────────────────────┐

│ 后端: 将可用奖品ID缓存到Redis │

│ Key: LUCKYTURN:PRIZEIDS:{mobile} │

│ Value: "A'", "B", "C'", "D'", "E"

└──────────────┬───────────────────────────┘

┌──────────────────────────────────────────┐

│ 前端: 渲染转盘,显示5个奖品 │

│ 用户看到的都是可抽的奖品 │

└──────────────┬───────────────────────────┘

⏰ 用户做任务、浏览...

┌──────────────────────────────────────────┐

│ T2: 用户点击抽奖 │

└──────────────┬───────────────────────────┘

┌──────────────────────────────────────────┐

│ 后端: 从Redis获取缓存的奖品ID列表 │

"A'", "B", "C'", "D'", "E"

│ ⚠️ 注意: 这里不再查询备用奖池! │

└──────────────┬───────────────────────────┘

┌──────────────────────────────────────────┐

│ 后端: 从这5个奖品中按概率抽取 │

│ 假设抽中: "C'" (来自备用奖池的奖品) │

└──────────────┬───────────────────────────┘

┌──────────────────────────────────────────┐

│ 后端: 返回中奖结果 │

│ { winPrizeId: "C'", ... } │

└──────────────┬───────────────────────────┘

┌──────────────────────────────────────────┐

│ 前端: 在转盘上找到"C'"的索引 │

│ 转盘转到对应位置 │

│ 显示中奖弹窗 │

└──────────────────────────────────────────┘

写法(最优、性能最好、Oracle 标准)

复制代码
STARTDATE >= TRUNC(SYSDATE, 'MM')

最快 (可以走索引)✅ 最标准 (Oracle 专用)✅ 最准确

格式化写法(慢,不推荐)

复制代码
TO_CHAR(STARTDATE, 'YYYY-MM') = TO_CHAR(SYSDATE, 'YYYY-MM')

❌ 无法用索引❌ 大数据量会卡

超简记忆

TRUNC (SYSDATE, 'MM') = 当月 1 号 >= 当月 1 号 = 查当月

相关推荐
星恒随风8 天前
C++ string 类详解:常用接口、OJ 场景与模拟实现中的深浅拷贝
开发语言·c++·笔记·学习·状态模式
colofullove9 天前
实时游玩页与 WebSocket 状态管理实现
websocket·网络协议·状态模式
夏天测10 天前
业务逻辑漏洞实战:篡改响应包绕过登录,直入后台管理系统
渗透测试·状态模式·业务逻辑漏洞·web 安全·响应包篡改
可乐ea10 天前
【Spring Boot + MyBatis|第7篇】JWT 登录认证与拦截器实现
java·spring boot·后端·mybatis·状态模式
前端不太难10 天前
GPU 集群调度架构解析
架构·状态模式
ShiJiuD66688899910 天前
外卖项目笔记总结上 (后端板块)
状态模式
前端不太难11 天前
当 AI 接管 Workspace:鸿蒙 PC Agent 架构设计实践
人工智能·状态模式·harmonyos
Maimai1080811 天前
Web3 前端实时通信如何落地:从 SSE 订阅到行情、订单与账户状态更新
前端·javascript·react.js·前端框架·web3·状态模式
不吃青椒!12 天前
LangGraph 流式事件处理:从实战到体系
ai·langchain·状态模式
前端不太难12 天前
鸿蒙游戏世界模型:实现原理 + Demo实现
游戏·状态模式·harmonyos