”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > 为什么在调用带有 Out 参数的存储过程时,PDO 会抛出“OUT 或 INOUT 参数...不是变量”?

为什么在调用带有 Out 参数的存储过程时,PDO 会抛出“OUT 或 INOUT 参数...不是变量”?

发布于2024-11-10
浏览:189

Why Does PDO Throw

使用 PDO 调用带输出参数的存储过程

使用 PDO 调用存储过程可以是一个无缝的过程;但是,当尝试使用不带 out 参数的存储过程时,可能会出现一个神秘的错误:

SQLSTATE[42000]: Syntax error or access violation: 1414 OUT or INOUT argument 1 for routine mydb.proc_OUT is not a variable or NEW pseudo-variable in BEFORE trigger

解决方案:PDO特殊性

深入研究 PDO 手册及其附带的讨论,揭示了 PDO 准备好的语句功能中的异常情况。问题的症结在于存储过程中 out 参数的处理。

要纠正此问题,需要特定的解决方法:

$stmt = $db->prepare("CALL SomeStoredProcedure(?, ?)"); 
$stmt->execute(array($someInParameter1, $someInParameter2));

替代方法

另一个选项涉及修改存储过程以包含检索的 SELECT 语句存储过程执行后的out参数:

CALL SomeStoredProcedure($someInParameter1, $someInParameter2, @someOutParameter); 
SELECT @someOutParameter;

这种修改后的方法模仿直接调用 MySQL 中的存储过程时观察到的行为。

通过采用这些解决方法,与使用 PDO 调用不带参数的存储过程相关的神秘错误消散,允许无缝执行和检索输出参数值。

最新教程 更多>
  • 如何在 PHP 中获取数组的前 N ​​个元素?
    如何在 PHP 中获取数组的前 N ​​个元素?
    如何在 PHP 中从数组中提取前 N 个元素检索数组的前 N ​​个元素是 PHP 中的常见任务发展。本简明指南将为您提供最有效的方法来实现此目的。解决方案:使用 array_slice()PHP 提供了强大的 array_slice() 函数来提取数组中指定的元素子集。其语法如下:array_sl...
    编程 发布于2024-11-18
  • 如何在 Yii2 高级应用中完全隐藏前后端路径?
    如何在 Yii2 高级应用中完全隐藏前后端路径?
    完全隐藏 Yii2 前端和后端路径理解问题Yii2 的高级应用程序模板在单独的目录中创建前端和后端部分。默认情况下,这些目录出现在 URL 中,这对于干净且专业的演示文稿来说可能是不可取的。本文旨在指导您完全隐藏这些目录。分步指南1.根.htaccess配置在项目的根目录(例如advanced/)中...
    编程 发布于2024-11-18
  • 如何使用 MySQL 查找今天生日的用户?
    如何使用 MySQL 查找今天生日的用户?
    如何使用 MySQL 识别今天生日的用户使用 MySQL 确定今天是否是用户的生日涉及查找生日匹配的所有行今天的日期。这可以通过一个简单的 MySQL 查询来实现,该查询将存储为 UNIX 时间戳的生日与今天的日期进行比较。以下 SQL 查询将获取今天有生日的所有用户: FROM USERS ...
    编程 发布于2024-11-18
  • 在 Go 中使用 WebSocket 进行实时通信
    在 Go 中使用 WebSocket 进行实时通信
    构建需要实时更新的应用程序(例如聊天应用程序、实时通知或协作工具)需要一种比传统 HTTP 更快、更具交互性的通信方法。这就是 WebSockets 发挥作用的地方!今天,我们将探讨如何在 Go 中使用 WebSocket,以便您可以向应用程序添加实时功能。 在这篇文章中,我们将介绍: WebSoc...
    编程 发布于2024-11-18
  • 如何在 Go 中反序列化动态嵌套 JSON 结构?
    如何在 Go 中反序列化动态嵌套 JSON 结构?
    在 Go 中解码嵌套动态 JSON 结构在 Go 中,使用嵌套动态结构反序列化 JSON 数据可能具有挑战性。最近的查询说明了这个问题:{ "status": "OK", "status_code": 100, &q...
    编程 发布于2024-11-18
  • 为什么布尔值在 C++ 中尽管是二进制的却占用一个字节?
    为什么布尔值在 C++ 中尽管是二进制的却占用一个字节?
    为什么布尔数据类型占用一个字节在 C 中,布尔值占用一个字节的内存,尽管它们具有二进制性质。这是硬件限制的结果,而不是数据类型的任何固有属性。底层硬件,特别是 CPU,无法有效地寻址和操作小于字节的数据。通过要求布尔值占用一个字节,CPU 简化了内存管理并优化了性能。不存在较小的整数类型同样,不存在...
    编程 发布于2024-11-18
  • 如何从 PHP 中的一维数组生成所有可能的组合,包括组合和排列?
    如何从 PHP 中的一维数组生成所有可能的组合,包括组合和排列?
    在 PHP 中获取所有可能的组合:综合解决方案从一维数组中检索所有可能的组合可能是一项复杂的任务,尤其是当考虑组合和排列。虽然解决这个问题有多种方法,但一种高效的解决方案涉及实现递归函数。递归函数,深度_picker(),对数组执行深度优先搜索,探索所有分支并组合元素以形成组合。它维护一个临时字符串...
    编程 发布于2024-11-18
  • 您需要了解的高级 Java Stream 技巧
    您需要了解的高级 Java Stream 技巧
    1. 创建映射来缓存实体 在 Map 中缓存实体可以通过减少从数据库或其他数据源重复获取数据的需要来提高性能。使用Java Streams,您可以轻松创建这样的缓存。 示例代码 import java.util.List; import java.util.Map; import...
    编程 发布于2024-11-18
  • 如何从 PHP 字符串中的字符中删除重音符号而不遇到意外的替换?
    如何从 PHP 字符串中的字符中删除重音符号而不遇到意外的替换?
    如何从 PHP 字符串中的字符中删除重音符号?在 glibc 实现中使用 iconv 可能会导致意外的字符替换,例如问号当尝试从 PHP 字符串中的字符中删除重音符号时。问题源于 iconv 和 glibc 实现之间的不兼容,它不如首选的 libiconv 实现可靠。要解决此问题,请确保 PHP 使...
    编程 发布于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
  • 想要速度吗?按价值传递:复制消除总是性能赢家吗?
    想要速度吗?按价值传递:复制消除总是性能赢家吗?
    想要速度?按值传递:性能注意事项“想要速度?按值传递”的原则表明,按值传递参数有时可以由于复制省略而提高性能。为了说明这一点,请考虑以下使用类 X 和 Y 的代码:struct X { std::string mem_name; X(std::string name) : mem_name(...
    编程 发布于2024-11-18
  • 为什么我的MySQL存储过程无法成功执行事务?
    为什么我的MySQL存储过程无法成功执行事务?
    解决 MySQL 存储过程中的事务问题当尝试在 MySQL 存储过程中实现事务时,开发人员可能会遇到意外错误。本文将探讨可能阻止事务性存储过程成功执行的语法和逻辑错误。案例:一个不成功的事务开发人员在以下情况下遇到问题:尝试在存储过程中实现事务。尽管遵循了 MySQL 文档,但该过程未能成功执行并提...
    编程 发布于2024-11-18
  • 如何控制选择框选项的宽度?
    如何控制选择框选项的宽度?
    设置选择框选项的宽度在给定的 HTML 代码中,选择框选项的宽度超过了选择框的宽度盒子本身。要解决此问题并确保选项宽度与选择框宽度对齐,我们应用 CSS 样式。CSS 解决方案:select, option { width: 250px; } option { overflow: h...
    编程 发布于2024-11-18
  • 如何在迭代时安全地从 `std::vector` 中删除元素?
    如何在迭代时安全地从 `std::vector` 中删除元素?
    从 std::vector 迭代和擦除迭代 std::vector 的推荐方法是使用迭代器。然而,在迭代时擦除元素可能会使迭代器失效。要解决这个问题,在擦除元素后修改迭代器赋值至关重要,如下所示:for (iterator it = begin; it != end(container) /* !!...
    编程 发布于2024-11-18
  • 如何使 Overlay Div 对鼠标事件“不可见”?
    如何使 Overlay Div 对鼠标事件“不可见”?
    确保元素对鼠标事件的响应在某些情况下,有必要在文本上覆盖透明 div 以掩盖其可见性。然而,这引发了覆盖层阻止底层文本可点击的问题。有没有办法使覆盖层对鼠标事件“不可见”,从而允许与下面的文本交互?例如,如果我们有以下 HTML 结构:<div id="container"...
    编程 发布于2024-11-18

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

Copyright© 2022 湘ICP备2022001581号-3