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票时,其中一半没有保存下来
知道为什么吗
更新:
未保存的数据:
注意,使用更新查询时有一个问题。例如:在您上面的代码中,您正在使用更新
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()