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

问题描述

所以我正在使用具有这样代码的投票系统

 <ResponsiveContainer width={"100%"} aspect={1}>

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

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

知道为什么吗?

更新: 未保存的数据:

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

解决方法

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

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

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

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

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...