有个关于数据库交易记录和余额计算的问题,求指导

查看 70|回复 7
作者:turan12   
最近正在开发的系统里有使用到账户资金交易和余额的内容。
目前使用的方式是:
record 表:记录所有用户的交易流水
balance 表:记录用户余额
需要使用余额的时候,直接根据 userid 从 balance 表里读出。
我的问题是,如果去掉 balance 表,需要读取余额的时候直接从 record 表里使用 sql sum()计算得出,是否可行?
ttvv123   
那就要看你的数据量了
turan12
OP
  
数据量不大,用户 5w 左右,每天交易大概 2-3k 笔。
LeeReamond   
@ttvv123 除非是个人使用的管理后台,就算是企业内部后台也没法用这种方式的,复杂度从 O(1)转成 O(2^n)了
shoaly   
我的建议是做日结, 然后 任意时候的余额 = 头一天的余额汇总 + 今天的 交易 sum()
crysislinux   
肯定不行的,数据量一上来性能太差了。event sourcing 就是你这种思路,但是性能也要靠 projection 来保证。
512357301   
record 记录流水和每笔交易的余额不就行了,直接省了 balance 表
turan12
OP
  
@shoaly 这个办法好
您需要登录后才可以回帖 登录 | 立即注册

返回顶部