Warning: file_get_contents(/data/phpspider/zhask/data//catemap/8/mysql/72.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Php 同时运行的投票系统未全部保存_Php_Mysql_Laravel_Voting_Voting System - Fatal编程技术网

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

Php 同时运行的投票系统未全部保存,php,mysql,laravel,voting,voting-system,Php,Mysql,Laravel,Voting,Voting System,所以我在投票系统工作,它有这样的代码 public function storeVote(Request $request) { $voting = Voting::findOrFail($request->voting_id); if($voting->status == 1){ $checkVote = vote::where('voting_id',$request->voting_id)->w

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

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'
                    ]);
        }
    }
因此,该功能作为用户投票的一种方式,参与者有一个唯一的链接,他们只需要选择候选人,然后它将触发上述功能

问题是,当我试着在同一时间投30票时,其中一半没有保存下来

知道为什么吗

更新: 未保存的数据:

  • 候选skor未更新或未乘以
  • 关于投票的投票信息,表示正在使用的总投票数

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

    $skor = $candidate->skor + 1;
    $candidate->skor = $skor;
    $candidate->update();
    
    当服务器获取同一路由的多个并发请求时,就会出现问题。对于每个请求(假设您有5个请求),函数检索旧的
    candidate_skore
    值,假设它等于1。现在,当它们中的每一个更新值DB value时,它将等于2。即使有5个upvote请求应该将DB值更新为6,但它只会更新为2,从而导致您丢失4个投票


    理想情况下,您应该为收到的所有投票保留一个关系表,并且只将其插入该关系表中。这样,即使同时提供请求,所有请求都将向表中插入新条目。最后,您的总投票数应等于该关系表中所有行的计数。

    请提供更多详细信息。什么不是拯救?您是否有任何错误?是否有任何错误?而不是使用
    $checkVote->update()
    $voting->update()
    尝试将它们更改为
    $checkVote->save()
    $voting->save()