框架是yii2用戶表中一個(gè)余額字段balance.用戶1 userId=1 現(xiàn)在余額 100.00 元用戶2 userId=2和用戶3 userId=3 同時(shí)向用戶1轉(zhuǎn)款100元。這是當(dāng)時(shí)的情況。轉(zhuǎn)賬用的方法:public function transfer(){ $userId = 1; $user = User::findOne($userId); $newBalance = $user['balance'] + 100; $user->balance = $newBalance; $user->save(false); }用戶2,3同時(shí)轉(zhuǎn)賬,但是用戶1只能收到100元。。。只能用鎖的方式或者原生sql語(yǔ)句來(lái)保證數(shù)據(jù)的正確性嗎?
2 回答

繁星淼淼
TA貢獻(xiàn)1775條經(jīng)驗(yàn) 獲得超11個(gè)贊
更新余額你可以換種方式,不用先查出來(lái)再update;而是直接更新,sql就是set balance = balance + 100

呼如林
TA貢獻(xiàn)1798條經(jīng)驗(yàn) 獲得超3個(gè)贊
這種我一般使用原生SQL來(lái)做。
sql
UPDATE USER SET balance=balance+100 WHERE user_id=:uid;
yii2
Yii::$app->db->createCommand($sql,[':uid'=>$userId])->execute();
- 2 回答
- 0 關(guān)注
- 1932 瀏覽
添加回答
舉報(bào)
0/150
提交
取消