”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > 为什么我的MySQL存储过程无法成功执行事务?

为什么我的MySQL存储过程无法成功执行事务?

发布于2024-11-18
浏览:758

Why Do My MySQL Stored Procedures Fail to Execute Transactions Successfully?

解决 MySQL 存储过程中的事务问题

当尝试在 MySQL 存储过程中实现事务时,开发人员可能会遇到意外错误。本文将探讨可能阻止事务性存储过程成功执行的语法和逻辑错误。

案例:一个不成功的事务

开发人员在以下情况下遇到问题:尝试在存储过程中实现事务。尽管遵循了 MySQL 文档,但该过程未能成功执行并提示无法保存更改。经过进一步检查,代码在语法上似乎是正确的。

分析代码

提供的代码片段如下:

BEGIN

DECLARE poid INT;

DECLARE EXIT HANDLER FOR SQLEXCEPTION SQLWARNING
BEGIN
    ROLLBACK;
END

START TRANSACTION;

    -- ADD option 5
    INSERT INTO product_option(product_id,option_id,required) VALUES(insertedProductID,5,0);
    SET poid = (SELECT LAST_INSERT_ID());
    INSERT INTO product_option_value(product_option_id,product_id,option_id,option_value_id,quantity,subtract,price,price_prefix,points,points_prefix,weight,weight_prefix) VALUES(poid,insertedProductID,5,50,0,0,4.99,' ',0,' ',0,' ');

    -- ADD option 12
    INSERT INTO product_option(product_id,option_id,required) VALUES(insertedProductID,12,1);

    -- ADD option 13
    INSERT INTO product_option(product_id,option_id,required) VALUES(insertedProductID,13,0);

COMMIT;

END

识别错误

经过仔细检查,发现两个语法错误:

  1. 缺少逗号退出处理程序:

    • 在 EXIT HANDLER 声明中,应该有用逗号分隔条件。
  2. 缺少分号:

    • EXIT HANDLER 的 END 语句缺少终止符分号。

The更正后的代码

更正后的代码如下:

BEGIN

DECLARE poid INT;

DECLARE EXIT HANDLER FOR SQLEXCEPTION, SQLWARNING
BEGIN
    ROLLBACK;
END;

START TRANSACTION;

    -- ADD option 5
    INSERT INTO product_option(product_id,option_id,required) VALUES(insertedProductID,5,0);
    SET poid = (SELECT LAST_INSERT_ID());
    INSERT INTO product_option_value(product_option_id,product_id,option_id,option_value_id,quantity,subtract,price,price_prefix,points,points_prefix,weight,weight_prefix) VALUES(poid,insertedProductID,5,50,0,0,4.99,' ',0,' ',0,' ');

    -- ADD option 12
    INSERT INTO product_option(product_id,option_id,required) VALUES(insertedProductID,12,1);

    -- ADD option 13
    INSERT INTO product_option(product_id,option_id,required) VALUES(insertedProductID,13,0);

COMMIT;

END;
最新教程 更多>
  • 如何在 Chrome DevTools 中访问 c​​hrome.storage.sync 数据?
    如何在 Chrome DevTools 中访问 c​​hrome.storage.sync 数据?
    在 Chrome DevTools 中访问 c​​hrome.storage.sync尽管 Chrome DevTools 中提供了本地存储和会话存储检查器,但用户经常遇到 chrome.storage.sync 缺少类似功能的情况。这可以通过替代方法解决。使用扩展程序进行 Chrome 存储检查存...
    编程 发布于2024-11-18
  • Scala Actor 可以替代 Go 的 Goroutine 进行库移植吗?
    Scala Actor 可以替代 Go 的 Goroutine 进行库移植吗?
    协程和 Actor:Go 和 Scala 的比较分析Actor 模型和 Goroutines 之间的相似之处让一些人质疑 Scala 是否可能是一种适合移植利用 Goroutines 的 Go 库的语言。然而,仔细检查就会发现这两个概念之间存在显着差异。协程:通信顺序进程 (CSP) 的基础Go 中...
    编程 发布于2024-11-18
  • 在 Go 中使用 WebSocket 进行实时通信
    在 Go 中使用 WebSocket 进行实时通信
    构建需要实时更新的应用程序(例如聊天应用程序、实时通知或协作工具)需要一种比传统 HTTP 更快、更具交互性的通信方法。这就是 WebSockets 发挥作用的地方!今天,我们将探讨如何在 Go 中使用 WebSocket,以便您可以向应用程序添加实时功能。 在这篇文章中,我们将介绍: WebSoc...
    编程 发布于2024-11-18
  • 如何在 PHP 中组合两个关联数组,同时保留唯一 ID 并处理重复名称?
    如何在 PHP 中组合两个关联数组,同时保留唯一 ID 并处理重复名称?
    在 PHP 中组合关联数组在 PHP 中,将两个关联数组组合成一个数组是一项常见任务。考虑以下请求:问题描述:提供的代码定义了两个关联数组,$array1 和 $array2。目标是创建一个新数组 $array3,它合并两个数组中的所有键值对。 此外,提供的数组具有唯一的 ID,而名称可能重合。要求...
    编程 发布于2024-11-18
  • 大批
    大批
    方法是可以在对象上调用的 fns 数组是对象,因此它们在 JS 中也有方法。 slice(begin):将数组的一部分提取到新数组中,而不改变原始数组。 let arr = ['a','b','c','d','e']; // Usecase: Extract till index p...
    编程 发布于2024-11-18
  • Python 的字符串连接优化适用于大字符串吗?
    Python 的字符串连接优化适用于大字符串吗?
    如何在 Python 中高效地将一个字符串附加到另一个字符串在 Python 中,使用 ' ' 运算符连接字符串是一项常见任务。虽然下面的代码很简单:var1 = "foo" var2 = "bar" var3 = var1 var2它提出...
    编程 发布于2024-11-18
  • 如何使用 PHP 的 `strtotime()` 和替代方案处理 1970 年之前的日期?
    如何使用 PHP 的 `strtotime()` 和替代方案处理 1970 年之前的日期?
    strtotime() 和 1970 年之前的日期由于范围有限,使用 strtotime() 处理 1970 年之前的日期可能会带来挑战。要解决此问题,请检查您的 PHP 版本和平台。如有必要,请考虑升级。或者,为了更灵活地处理更广泛的日期范围,请考虑使用 PHP 的 DateTime 对象。它们允...
    编程 发布于2024-11-18
  • 尽管代码有效,为什么 POST 请求无法捕获 PHP 中的输入?
    尽管代码有效,为什么 POST 请求无法捕获 PHP 中的输入?
    解决 PHP 中的 POST 请求故障在提供的代码片段中:action=''而不是:action="<?php echo $_SERVER['PHP_SELF'];?>";?>"检查 $_POST数组:表单提交后使用 var_dump 检查 $_POST 数...
    编程 发布于2024-11-18
  • 超越分析器:我们如何实现准确的性能优化?
    超越分析器:我们如何实现准确的性能优化?
    超越分析器:探索替代性能优化技术在他的演讲“性能焦虑”中,Joshua Bloch 强调了分析器的局限性及其潜在的不准确性。然而,这提出了一个问题:我们还有哪些其他选项来优化性能?我们应该回归我们的直觉和猜测吗?Bloch 引用的论文“评估 Java 分析器的准确性”中得出的结论是,分析器可能由于不...
    编程 发布于2024-11-18
  • Pandas 中的 inplace=True 真的值得冒险吗?
    Pandas 中的 inplace=True 真的值得冒险吗?
    在 Pandas 中,Inplace = True 被认为是有害的吗?简介:概念Pandas 中的“就地修改”长期以来一直是争论的话题。在本文中,我们将探讨为什么 inplace = False 是 Pandas 中的默认行为、何时考虑切换到 inplace = True 以及与其使用相关的潜在风险...
    编程 发布于2024-11-18
  • 如何避免 Lambda 函数中的参数修改导致意外结果
    如何避免 Lambda 函数中的参数修改导致意外结果
    Lambda 函数及其参数的范围Lambda 函数是匿名函数,可以捕获其封闭函数的范围。这允许他们从父作用域访问变量和参数。但是,当 lambda 函数使用在封闭函数内修改的参数时,此行为有时会导致意外结果。要说明此问题,请考虑以下代码:def callback(msg): print(ms...
    编程 发布于2024-11-18
  • 如何在 PHP 中从变量实例化类?
    如何在 PHP 中从变量实例化类?
    在 PHP 中从变量实现类实例化在 PHP 中,您可能会遇到需要从变量的值实例化类的场景。让我们用一个例子来说明这一点:$var = 'bar'; $bar = new {$var}Class('var for __construct()'); //$bar = new barClass('var ...
    编程 发布于2024-11-18
  • 如何修复 macOS 上 Django 中的“配置不正确:加载 MySQLdb 模块时出错”?
    如何修复 macOS 上 Django 中的“配置不正确:加载 MySQLdb 模块时出错”?
    MySQL配置不正确:相对路径的问题在Django中运行python manage.py runserver时,可能会遇到以下错误:ImproperlyConfigured: Error loading MySQLdb module: dlopen(/Library/Python/2.7/site-...
    编程 发布于2024-11-18
  • Bootstrap 4 Beta 中的列偏移发生了什么?
    Bootstrap 4 Beta 中的列偏移发生了什么?
    Bootstrap 4 Beta:列偏移的删除和恢复Bootstrap 4 在其 Beta 1 版本中引入了重大更改柱子偏移了。然而,随着 Beta 2 的后续发布,这些变化已经逆转。从 offset-md-* 到 ml-auto在 Bootstrap 4 Beta 1 中, offset-md-*...
    编程 发布于2024-11-18
  • 我需要带有准备好的语句的“mysql_real_escape_string()”吗?
    我需要带有准备好的语句的“mysql_real_escape_string()”吗?
    准备好的语句是否需要 mysql_real_escape_string() 函数?当使用给定查询中的准备好的语句时:$sql = $db->prepare('select location from location_job where location like ?'); $sql->...
    编程 发布于2024-11-18

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3