第一次做支付系統(tǒng),我們平臺(tái)有很多商戶,每個(gè)商戶每分鐘訂單很多,量很大,我用異步方式給商戶賬戶更新余額,用的mysql隊(duì)列,每筆訂單成功都會(huì)往隊(duì)列里加如一條,crontab來(lái)讀取更新增加賬戶余額,但是碰到了一個(gè)提現(xiàn)的問(wèn)題提現(xiàn)我是這么做的,賬戶余額減去提現(xiàn)金額,然后再把剩余的錢(qián)更新到賬戶余額字段,問(wèn)題就有了!1.提現(xiàn)的時(shí)候拿到賬戶余額為10塊,要提現(xiàn)5塊,提現(xiàn)操作正在進(jìn)行,但是這個(gè)時(shí)候進(jìn)來(lái)一筆5塊的訂單,異步要更新賬戶,拿到的還是10塊,加上5塊,然后把15元更新到余額字段中,這時(shí)候提現(xiàn)操作也在進(jìn)行,提現(xiàn)了5塊,然后在把剩余的5塊更新到余額字段, 覆蓋了之前的15,2.我沒(méi)有在提現(xiàn)查詢余額的時(shí)候加鎖,加鎖能否解決問(wèn)題呢,除了加鎖,是否還有其他更好的方法解決呢。這個(gè)異步更新賬戶余額的邏輯和提現(xiàn)的邏輯是否需要改進(jìn)呢。希望大家能能大家給點(diǎn)意見(jiàn)謝謝第一條是入賬的,第一個(gè)字段是ID 第二個(gè)余額,第三個(gè)訂單金額,第四個(gè)更新完后的余額,第二條是提現(xiàn)的,第二個(gè)余額,第三個(gè)是提現(xiàn)的金額,第四個(gè)同上
1 回答

動(dòng)漫人物
TA貢獻(xiàn)1815條經(jīng)驗(yàn) 獲得超10個(gè)贊
增加余額
set autocommit=0;update <table> set balance=balance+<xxx> where id=<id>;select * from <table> where id=<id>commit;
保證上面2條語(yǔ)句在同一個(gè)事務(wù)中執(zhí)行。最終在程序中做運(yùn)算。
balance - <xxx>
就是增加前的余額
balance
就是增加后的余額
提現(xiàn)
set autocommit=0;update <table> set balance=balance-<xxx> where id=<id> and balance>=<xxx>;select * from <table> where id=<id>;commit;
保證上面2條語(yǔ)句在同一個(gè)事務(wù)中執(zhí)行。最終在程序中做運(yùn)算。
balance + <xxx>
就是提現(xiàn)前的余額
balance
就是提現(xiàn)后的余額
- 1 回答
- 0 關(guān)注
- 991 瀏覽
添加回答
舉報(bào)
0/150
提交
取消