我有一张桌子tbl_orders
。它有一个数量字段quantity
。
在我的应用程序的某些部分,我需要将数量减少1。
我已经知道记录的id
(可从客户端获得),因此我发出了更新声明:
UPDATE tbl_orders
SET quantity=quantity-1
WHERE id= 6
问题是此查询可能会意外地同时运行多次。 例如,2个客户服务运营商可以同时更新同一记录。 这意味着当数量应该仅减少一次时,数量将减少2。
我尝试将更新放在一个事务中,但这导致只延迟第二个事务,直到第一个事务被提交。一旦提交,第二次更新就会再次运行并递减记录。
如果正在修改记录,如何确保其他查询失败?
更新
要使更新生效,客户端的数量在数据库中是相同的。例如,如果用户在其浏览器上看到数量5并想要减少它,则数据库中的值必须相同。
更新2
我发现了使用Doctrine 2进行乐观锁定的一个很好的解释here:
答案 0 :(得分:5)
我过去使用/看过的一种方法是使用时间戳列。查询时,请确保在编辑记录开始时同时具有ID和原始时间戳。然后,当您尝试更新时,请通过
发送update YourTable
set counter = counter -1,
TheTimestampColumn = new timestamp value
where ID = yourID
and TheTimeStampColumn = timeStampEditStartedWith
这样,无论谁先使用原始开始时间戳获得它都会获胜。对于下面的一个,您必须跟踪更新的记录数,如果该计数等于零,那么您将通知用户另一个人在您查看记录时对记录进行了更改。您想重新加载最新数据吗? (或类似的东西)。