gpt4 book ai didi

php - MySQL 如何同时管理来自多个用户的多个查询?

转载 作者:可可西里 更新时间:2023-11-01 06:49:20 25 4
gpt4 key购买 nike

举个例子:

我有一个管理用户投票的 PHP 脚本。

当用户投票时,脚本会查询以检查是否有人已经为相同的 ID/产品投票。如果没有人投票,那么它会进行另一个查询并将 ID 插入到通用 ID 投票表中,然后再进行一次查询以将数据插入到每个用户 ID 投票表中。这种行为在其他类型的脚本中重复出现。

问题是,如果两个不同的用户同时投票,代码的两个实例可能会尝试插入一个新的 ID(或某种类似类型的查询),这会产生错误??

如果是,我如何防止这种情况发生?

谢谢?

重要提示:我正在使用 MyISAM!我的虚拟主机不允许 InnoDB。

最佳答案

The question is, if two different users votes simultaneously its possible that the two instances of the code try to insert a new ID (or some similar type of query) that will give an erro

是的,您最终可能会通过两个查询执行插入。根据表的约束,其中之一会产生错误,或者您最终会在数据库中有两行。

我相信你可以通过应用一些锁定来解决这个问题;例如如果需要给id为theProductId的产品投票:(伪代码)

START TRANSACTION;
//lock on the row for our product id (assumes the product really exists)
select 1 from products where id=theProductId for update;
//assume the vote exist, and increment the no.of votes
update votes set numberOfVotes = numberOfVotes + 1 where productId=theProductId ;
//if the last update didn't affect any rows, the row didn't exist
if(rowsAffected == 0)
insert into votes(numberOfVotes,productId) values(1,theProductId )
//insert the new vote in the per user votes
insert into user_votes(productId,userId) values(theProductId,theUserId);
COMMIT;

更多信息 here

MySQL 还提供了另一种解决方案,可能适用于此,insert on duplicate

例如你也许可以这样做:

 insert into votes(numberOfVotes,productId) values(1,theProductId ) on duplicate key 
update numberOfVotes = numberOfVotes + 1;

如果您的投票表在产品 ID 列上有一个唯一键,上面将如果特定的 theProductId 不存在,则执行插入,否则它将执行更新,其中它将 numberOfVotes 列递增 1

如果在将产品添加到数据库的同时在投票表中创建一行,则可能会避免很多这样的情况。这样您就可以确定您的产品始终有一行,并且只需对该行发出更新。

关于php - MySQL 如何同时管理来自多个用户的多个查询?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3851767/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com