同时运行的投票系统未全部保存

Voting system that being run at the same time not all saved

所以我在有这样代码的投票系统工作

public function storeVote(Request $request)
    {   
        $voting = Voting::findOrFail($request->voting_id);

        if($voting->status == 1){
            $checkVote = vote::where('voting_id',$request->voting_id)->where('name',$request->name)->where('voting_candidate_id',null)->first();
    
            if($checkVote){
                \DB::beginTransaction(); 
                try{
                    $candidate = candidate::findOrFail($request->voting_candidate_id);
                    $skor = $candidate->skor + 1;
                    $candidate->skor = $skor;
                    $candidate->update();
            
                    $checkVote->voting_candidate_id = $request->voting_candidate_id;
                    $checkVote->update();
    
                    $vote_ok = $voting->vote_ok + 1;
                    $voting->vote_ok = $vote_ok;
                    $voting->update();
                    
                    event(new VotingEvent($skor, $voting->id, $candidate->id));

                    CandidateProfile::flushCache();
                    
                    \DB::commit();
                    return response()
                        ->json([
                            'saved' => true,
                            'message' => 'Voting done.',
                        ]); 
                } catch (\Exception $e){
                    \DB::rollBack();
                    abort(500, $e->getMessage());
                }
            }else{
                return response()
                    ->json([
                        'saved' => false,
                        'message' => 'sorry, you already vote'
                    ]); 
            }
        }else{
            return response()
                    ->json([
                        'saved' => false,
                        'message' => 'Sorry, Voting session not started yet'
                    ]);
        }
    }

所以这个功能作为用户投票的一种方式,参与者有一个唯一的link,他们只需要选择候选人,然后就会触发上面的功能

问题是当我测试同时做30票时,其中一半没有保存。

知道为什么吗?

更新: 未保存的数据:

  1. 候选skor未更新或未相乘
  2. 关于 vote_ok 的投票信息,这意味着正在使用的总票数

请注意,使用更新查询时有一个问题。例如:在上面的代码中,您正在使用更新 candicate_skor;

$skor = $candidate->skor + 1;
$candidate->skor = $skor;
$candidate->update();

当您的服务器收到对同一路由的多个并发请求时,就会出现问题。对于每个请求(假设您有 5 个请求),该函数检索旧的 candidate_skore 值,假设它等于 1。现在,当它们中的每一个更新值 DB 值时,它将等于 2。即使尽管您有 5 个投票请求应该将 DB 值更新为 6,但它仅更新为 2,导致您失去 4 票。

理想情况下,您应该为收到的所有选票保留关系 table,并且只将其插入该关系 table。这样,即使同时请求得到服务,所有请求也会将新条目插入 table。最后,您的总票数应等于该关系中所有行的计数 table.