同时运行的投票系统未全部保存
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票时,其中一半没有保存。
知道为什么吗?
更新:
未保存的数据:
- 候选skor未更新或未相乘
- 关于 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.
所以我在有这样代码的投票系统工作
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票时,其中一半没有保存。
知道为什么吗?
更新: 未保存的数据:
- 候选skor未更新或未相乘
- 关于 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.