我有一个名为clone
的功能,我必须将数百万条记录从一个项目复制到另一个项目(多个表)。为此我使用MySQL
的存储过程。
DROP PROCEDURE IF EXISTS `clone_new`;
DELIMITER $$
CREATE PROCEDURE `clone_new`(
BEGIN
DECLARE EXIT HANDLER FOR SQLEXCEPTION
BEGIN
SHOW ERRORS;
ROLLBACK;
END;
START TRANSACTION;
INSERT INTO XXX SELECT * FROM XXXX ....
.....
.....
COMMIT;
END $$
DELIMITER ;
这里的问题是没有START TRANSACTION;
插入发生的速度很慢,但是由于START TRANSACTION;
MySQL
在该事务完成之前锁定了该表。这导致其他客户Connection Timeout
。
START TRANSACTION;
需要进行回滚。
如何在不影响其他用户的情况下获得性能?
注意:我们正在使用innodb
表。
答案 0 :(得分:0)
我已将Isolation Level
从REPEATABLE READ
更改为READ COMMITTED
来解决此问题。
我找到了这份文件。
在
REPEATABLE READ
中,在交易期间获得的每个锁都被保留 在交易期间。在
READ COMMITTED
中,释放与扫描不匹配的锁STATEMENT
完成后。