当我们遇到存在高并发并且对于数据的准确性有要求的场景,需要了解和使用for update
需要注意的点:
1、InnoDB默认是行级别的锁,当有明确指定的主键时候,是行级锁。否则是表级别
2、for update 仅适用于InnoDB,并且必选开启事务, 在begin与commit之间才生效
public function actionTest(){ $db = Yii::$app->db; $transaction = $db->beginTransaction(); try{ $sql = "select * from ".User::tableName()." where user_id=5 for update"; $userInfo = User::findBySql($sql)->one(); $userInfo->nickname= 'asfasdfasfdaf'; $userInfo->save(); $transaction->commit(); $this->success(); }catch (ServiceException $e){ $transaction->rollBack(); $this->error(); } }