繁体   English   中英

事务期间不会阻止SQL UPDATE / INSERTS

[英]SQL UPDATES/INSERTS are not getting blocked during a transaction

我有一个表,该表不断从其他进程发送更新/插入,并且正在尝试对我的SQL表执行事务,在该表中我旋转表并将一些最后的值移到刚创建的新表中:

BEGIN TRANSACTION;
CREATE TABLE temp LIKE sales;
RENAME TABLE sales TO sales_05_04_19, temp TO sales
INSERT INTO sales SELECT * FROM sales_05_04_19 WHERE time > 1556953200000;
COMMIT;

但是它似乎并没有阻止这些UPDATES / INSERTS,并且似乎确实可以在事务的INSERT发生之前将其直通到新创建的sales表。 这使我在事务插入上得到错误:

(1062, "Duplicate entry '1' for key 'PRIMARY'")

我认为该事务将阻止UPDATES / INSERTS,直到它提交为止,但在这里似乎并非如此。 所以我觉得我需要获得一把锁。 我将如何去做(如果这是解决此问题的正确方法)?

如果您想在执行此类操作时防止在表上进行更新,则需要锁定表而不是使用事务。 我建议创建新表,将其与旧表锁定,进行重命名switcheroo,进行插入,然后释放锁。 无需进行交易。 事务避免不一致,但是它们不能保证顺序,并且在任何情况下,诸如create和named表之类的DDL语句都不安全。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM