gpt4 book ai didi

mysql - 错误 1305 (42000) : SAVEPOINT . .. 不存在

转载 作者:可可西里 更新时间:2023-11-01 07:32:57 27 4
gpt4 key购买 nike

我的 MYSQL 数据库中有此 SQL(存储过程为空,所以我猜没有隐式提交?)。

DROP PROCEDURE IF EXISTS doOrder;

DELIMITER $$

CREATE PROCEDURE doOrder(IN orderUUID VARCHAR(40))
BEGIN
SAVEPOINT sp_doOrder;

BEGIN
DECLARE EXIT HANDLER FOR SQLEXCEPTION ROLLBACK TO sp_doOrder;

-- doing my updates and selects here...

END;

RELEASE SAVEPOINT sp_doOrder;
END $$

DELIMITER ;

当我

call doOrder('some-unique-id');

我得到:错误 1305 (42000):SAVEPOINT sp_doOrder 不存在。

我可能会忽略一些事情......有什么想法吗?

最佳答案

由于这是搜索“保存点不存在”时 Google 上的最佳答案,因此我也将在此处添加我的解决方案。

我在事务中执行的代码中有一个 TRUNCATE 语句,它导致了隐式提交并因此结束了事务。在事务之外创建保存点不会导致错误,它只是不会被执行。这意味着当您尝试释放保存点/将其回滚时,您会第一次注意到出现问题。

这是导致隐式提交的语句的完整列表:https://dev.mysql.com/doc/refman/5.7/en/implicit-commit.html

关于mysql - 错误 1305 (42000) : SAVEPOINT . .. 不存在,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19670095/

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