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超级智能客服

相关推荐
love530love1 小时前
LiveTalking 数字人项目 Windows 部署完全指南(EPGF 架构)
人工智能·windows·python·架构·livetalking·epgf
遇事不決洛必達1 小时前
【Python基础】GIL 锁是什么及其对爬虫的影响
爬虫·python·线程·进程·gil锁
Micro麦可乐1 小时前
Spring Boot 实战:从零设计一个短链系统(含完整代码与数据库设计)
数据库·spring boot·后端·哈希算法·雪花算法·短链系统
海兰1 小时前
【水浒传:第二篇】AI江湖 —项目详细设计指南(一)
jvm·人工智能·游戏
码农阿豪1 小时前
从零到一:Spring Boot快速接入金仓数据库实战
数据库·spring boot·后端
鼎讯信通2 小时前
风电光缆运维提质增效:G-4000A 光缆故障追踪仪破解风场巡检难题
运维·网络·数据库
CryptoPP2 小时前
快速对接东京证券交易所API数据:实战指南与代码示例
开发语言·人工智能·windows·python·信息可视化·区块链
三十..2 小时前
MySQL 从入门到高可用架构实战精要
运维·数据库·mysql
探物 AI3 小时前
把 MambaOut 塞进 YOLOv11:会有什么样的反应
python·yolo·计算机视觉
cfm_29143 小时前
Redis五大基本数据结构底层了解
数据结构·数据库·redis