奖池渲染以及中奖逻辑

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

│ 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 号 = 查当月

相关推荐
前端不太难5 小时前
鸿蒙 App 多端 UI 不一致的原因
ui·状态模式·harmonyos
jekc8686 小时前
金碟云星空附件上传
状态模式
前端不太难1 天前
鸿蒙 App 的登录 / 订单 / 支付系统拆解
华为·状态模式·harmonyos
码码哈哈0.02 天前
基于 RSA 非对称加密与挑战码机制的前端登录安全方案
前端·安全·状态模式
前端不太难2 天前
鸿蒙 App 的 Task + State 双核心架构
架构·状态模式·harmonyos
lichenyang4532 天前
从零理解微前端:基于 React + Vite + qiankun 的子应用切换 Demo
前端·react.js·状态模式
yuzhiboyouye3 天前
web前端英语面试
前端·面试·状态模式
van久3 天前
Day27:菜单管理 + 动态路由(前端可直接用!)
前端·状态模式
huohuopro3 天前
Spring MVC 的核心知识点梳理
spring·mvc·状态模式