turan12
V2EX  ›  问与答

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

  •  
  •   turan12 · May 12, 2024 · 1698 views
    This topic created in 733 days ago, the information mentioned may be changed or developed.
    最近正在开发的系统里有使用到账户资金交易和余额的内容。

    目前使用的方式是:
    record 表:记录所有用户的交易流水
    balance 表:记录用户余额
    需要使用余额的时候,直接根据 userid 从 balance 表里读出。

    我的问题是,如果去掉 balance 表,需要读取余额的时候直接从 record 表里使用 sql sum()计算得出,是否可行?
    10 replies    2024-05-13 09:38:53 +08:00
    ttvv123
        1
    ttvv123  
       May 12, 2024
    那就要看你的数据量了
    turan12
        2
    turan12  
    OP
       May 12, 2024
    数据量不大,用户 5w 左右,每天交易大概 2-3k 笔。
    LeeReamond
        3
    LeeReamond  
       May 12, 2024
    @ttvv123 除非是个人使用的管理后台,就算是企业内部后台也没法用这种方式的,复杂度从 O(1)转成 O(2^n)了
    shoaly
        4
    shoaly  
       May 12, 2024
    我的建议是做日结, 然后 任意时候的余额 = 头一天的余额汇总 + 今天的 交易 sum()
    crysislinux
        5
    crysislinux  
       May 12, 2024 via Android
    肯定不行的,数据量一上来性能太差了。event sourcing 就是你这种思路,但是性能也要靠 projection 来保证。
    512357301
        6
    512357301  
       May 12, 2024 via Android
    record 记录流水和每笔交易的余额不就行了,直接省了 balance 表
    turan12
        7
    turan12  
    OP
       May 13, 2024
    @shoaly 这个办法好
    laminux29
        8
    laminux29  
       May 13, 2024
    @turan12 运营商也是这个办理,只是结账周期会短一些,以及根据算力余量会动态一些。
    adimn
        9
    adimn  
       May 13, 2024
    record 表你不记录上次余额吗, 这样你就不用 sum 了
    yefee
        10
    yefee  
       May 13, 2024
    @512357301 这个办法在交易高峰期可能会出现问题,需要加锁
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   1034 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 56ms · UTC 18:32 · PVG 02:32 · LAX 11:32 · JFK 14:32
    ♥ Do have faith in what you're doing.