mysql如何设计积分系统_mysql流水账与余额对账

流水表必须带唯一业务单号trade_no并建唯一索引,用INSERT IGNORE或ON DUPLICATE KEY UPDATE防重;余额统一用BIGINT存最小单位,所有增减走原子UPDATE;对账分实时(查最近N条)与离线(每日全量SUM比对)两层;事务须同库同表,禁止跨库跨服务。流水表必须带唯一业务单号,不能只靠自增ID对账余额不准,90%出在流水重复或漏写。自增 id 只是插入顺序标识,不是业务凭证------同一笔充值可能因重试插入两次,而 id 不同但业务单号相同。流水表必须有 trade_no 字段(如 pay_202405211023456789),加唯一索引:UNIQUE KEY uk_trade_no (trade_no)写流水时用 INSERT IGNORE 或 ON DUPLICATE KEY UPDATE 拦住重复单号,而不是靠应用层"查一遍再插"对账脚本比对时,只以 trade_no 为基准,完全忽略 id 和插入时间余额字段别存浮点数,用 BIGINT 存「分」或「最小积分单位」MySQL 的 FLOAT / DOUBLE 会丢失精度,比如 0.1 + 0.2 ≠ 0.3,积分清零、发放、扣减全乱套。哪怕你用 DECIMAL(12,2),也扛不住高并发下的读写竞争和四舍五入误差。统一用 BIGINT,单位是「1积分」,不带小数------用户看到的 12.5 积分,在库里存 1250(单位=0.01分)或直接 125(单位=0.1分),看业务粒度所有增减操作走 UPDATE user_point SET balance = balance + ? WHERE user_id = ? AND trade_no = ?,避免先查后更新余额校验脚本里,SUM(amount) 流水总和必须和 balance 完全相等,差1都不行------这是对账硬门槛对账不是"跑个SQL",得区分「实时核对」和「离线兜底」线上服务不能每笔都查流水总和来校验余额,太慢;但完全不校,出错发现就晚了。得拆成两层:轻量实时校验 + 异步全量对账。 MacsMind 电商AI超级智能客服

相关推荐
NotFound4862 小时前
Golang怎么实现防重复提交_Golang如何用Token机制防止表单重复提交【技巧】
jvm·数据库·python
fly-iot2 小时前
TradingAgents 是一个模拟真实交易公司运作模式的多智能体交易框架,本地运行命令行工具,演示执行命令行模式,使用docker镜像打包
python·股票系统·tradingagents
2401_865439632 小时前
CSS如何实现图片自动裁剪填充_巧用object-fit属性控制尺寸
jvm·数据库·python
m0_748839492 小时前
HTML函数能否用液态金属散热提升性能_极端散热方案实测【汇总】
jvm·数据库·python
2301_803538952 小时前
mysql添加索引导致插入变慢怎么办_索引优化与异步处理方案
jvm·数据库·python
该醒醒了~2 小时前
深度学习异常检测Anomalib算法训练+推理+转化+onnx
人工智能·python·深度学习
2301_782659182 小时前
如何防止SQL脏数据写入_利用触发器实现强一致性校验
jvm·数据库·python
2301_817672262 小时前
如何实现元素从底部进入视口时触发 sticky 定位
jvm·数据库·python
日光明媚2 小时前
FFmpeg 视频生成推理 Pipeline:Python 版常用函数封装(可直接集成)
python·深度学习·ai作画·aigc·音视频