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

相关推荐
花酒锄作田13 小时前
Pydantic校验配置文件
python
hboot14 小时前
AI工程师第四课 - 深度学习入门
pytorch·python·神经网络
GBASE18 小时前
G术时刻 |GBase 8s数据库事务并发控制之封锁技术介绍(下)
数据库
ZhengEnCi1 天前
P2M-Matplotlib折线图完全指南-从数据可视化到趋势分析的Python绘图利器
python·matlab·数据可视化
ZhengEnCi1 天前
P2L-Matplotlib饼图完全指南-从数据可视化到图表定制的Python绘图利器
python·matlab
曲幽1 天前
你的REST接口还在“过度投喂”数据吗?——FastAPI + GraphQL实战避坑指南
python·fastapi·web·graphql·route·cors·rest·strawberry
用户8358086187911 天前
基于 Self-RAG 与列表级重排序的进阶 RAG 系统设计与实现
python
xiezhr1 天前
逛GitHub发现了一款免费的带AI功能的数据库管理工具
数据库·ai编程·dba
Warson_L2 天前
Python `Annotated` 与 LangGraph Reducer 学习笔记
python
韩师傅2 天前
海天线算法的前世今生
python·计算机视觉