”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > 如何调试 PDO 连接问题:为什么我的脚本尝试无限期连接?

如何调试 PDO 连接问题:为什么我的脚本尝试无限期连接?

发布于2024-11-15
浏览:870

How to Debug PDO Connection Issues: Why is My Script Trying to Connect Indefinitely?

PDO 连接测试:调试连接问题

在为您的应用程序之一创建安装程序的过程中,您在通过 PDO 测试数据库设置时遇到了挑战。通过提供的代码片段,您发现脚本尝试无限期地连接到数据库,尽管明显的连接失败。

要纠正此问题并能够区分有效和无效的数据库连接,您需要设置错误建立 PDO 连接时的模式。具体方法如下:

try{
    $dbh = new pdo( 'mysql:host=127.0.0.1:3308;dbname=axpdb',
                    'admin',
                    '1234',
                    array(PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION));
    die(json_encode(array('outcome' => true)));
}
catch(PDOException $ex){
    die(json_encode(array('outcome' => false, 'message' => 'Unable to connect')));
}

通过将 PDO::ATTR_ERRMODE 设置为 PDO::ERRMODE_EXCEPTION,PDO 在连接过程中遇到任何错误都会抛出异常。这允许您在错误处理程序中捕获这些异常,并向用户提供有意义的错误消息。

有关 PDO 中错误处理的更多信息,您可以参考以下资源:

  • 将 MySQL 与 PDO 结合使用
  • 错误和错误处理
最新教程 更多>
  • 如何使用 MySQL 查找今天生日的用户?
    如何使用 MySQL 查找今天生日的用户?
    如何使用 MySQL 识别今天生日的用户使用 MySQL 确定今天是否是用户的生日涉及查找生日匹配的所有行今天的日期。这可以通过一个简单的 MySQL 查询来实现,该查询将存储为 UNIX 时间戳的生日与今天的日期进行比较。以下 SQL 查询将获取今天有生日的所有用户: FROM USERS ...
    编程 发布于2024-11-15
  • 大批
    大批
    方法是可以在对象上调用的 fns 数组是对象,因此它们在 JS 中也有方法。 slice(begin):将数组的一部分提取到新数组中,而不改变原始数组。 let arr = ['a','b','c','d','e']; // Usecase: Extract till index p...
    编程 发布于2024-11-15
  • 为什么我的 @font-face EOT 字体无法在 Internet Explorer 中通过 HTTPS 加载?
    为什么我的 @font-face EOT 字体无法在 Internet Explorer 中通过 HTTPS 加载?
    @font-face EOT 无法通过 HTTPS 加载:解决方案遇到 @font-face EOT 文件在 Internet 中无法通过 HTTPS 加载的问题在 Explorer 版本 7、8 和 9 中,用户发现无论 HTTPS 上包含的 HTML 页面的托管状态如何,问题仍然存在。经过实验,...
    编程 发布于2024-11-15
  • 为什么通过 Makefile 运行 Go 程序时出现“权限被拒绝”错误?
    为什么通过 Makefile 运行 Go 程序时出现“权限被拒绝”错误?
    权限被拒绝:调查“go run”和 Makefile 调用之间的差异通过 Makefile 运行 Go 程序时遇到权限被拒绝错误可能会令人困惑。此问题源于 GNU make 或其 gnulib 组件中的错误。根本原因在于系统 PATH 中存在一个名为“go”的目录,该目录位于实际 Go 可执行文件所...
    编程 发布于2024-11-15
  • 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-15
  • 可以使用 CSS 设计 SVG 背景图像吗?
    可以使用 CSS 设计 SVG 背景图像吗?
    您可以使用 CSS 设计 SVG 背景图像吗?作为 SVG 爱好者,您精通将 SVG 用作背景图像。然而,仍然存在一个持续存在的问题:您是否也可以在同一个文件中使用 CSS 设计 SVG 样式?遗憾的是,答案是不。用作背景图像的 SVG 被视为与 CSS 样式表隔离的单个实体。 CSS 文件中的样式...
    编程 发布于2024-11-15
  • 能否结合使用 LIKE 和 IN 来实现更强大的 SQL 查询?
    能否结合使用 LIKE 和 IN 来实现更强大的 SQL 查询?
    结合LIKE和IN进行高级SQL查询在SQL中,LIKE运算符经常用于模式匹配,而IN运算符允许我们将一个值与一系列特定值进行匹配。虽然这些运算符有不同的用途,但可以将它们组合起来创建更强大的查询。让我们考虑以下场景:您有一个表,其中有一列名为“company_id”,并且您想要选择其中包含该列的所...
    编程 发布于2024-11-15
  • 为什么PHP中逗号可以用于回显但不能用于返回?
    为什么PHP中逗号可以用于回显但不能用于返回?
    为什么用逗号回显有效,而用逗号返回却不起作用?在 PHP 中使用 echo 和 return 连接值时,有使用句号和逗号之间的细微差别。具体来说:Echo:允许以逗号分隔的多个表达式回显到输出。返回:只能返回一个单个表达式。使用句点句点 (.) 运算符将字符串或其他数据类型连接成单个字符串。例如:e...
    编程 发布于2024-11-15
  • 如何将 Django 数据库从 SQLite 迁移到 MySQL:分步指南
    如何将 Django 数据库从 SQLite 迁移到 MySQL:分步指南
    将 Django DB 从 SQLite 迁移到 MySQL将数据库从 SQLite 迁移到 MySQL 可能是一项艰巨的任务。由于可用的工具和脚本过多,因此很难确定最可靠和最直接的方法。一位经验丰富的 Django 开发人员建议了一个经受时间考验的解决方案。他们建议执行以下步骤:转储现有的 SQL...
    编程 发布于2024-11-15
  • 如何确保 JavaScript 中准确的整数验证:哪种方法最好?
    如何确保 JavaScript 中准确的整数验证:哪种方法最好?
    如何在 JavaScript 中验证整数输入无论是需要检查整数以确保数据一致性,还是需要向用户提示准确的错误消息,JavaScript 提供了多种验证方法整数输入。一种常见的方法是使用 parseInt() 函数。但是,如果您想要处理可能被解析为整数的字符串等场景,仅此方法可能不够。稳健的整数验证函...
    编程 发布于2024-11-15
  • 如何修复 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-15
  • 在 Go 中使用 WebSocket 进行实时通信
    在 Go 中使用 WebSocket 进行实时通信
    构建需要实时更新的应用程序(例如聊天应用程序、实时通知或协作工具)需要一种比传统 HTTP 更快、更具交互性的通信方法。这就是 WebSockets 发挥作用的地方!今天,我们将探讨如何在 Go 中使用 WebSocket,以便您可以向应用程序添加实时功能。 在这篇文章中,我们将介绍: WebSoc...
    编程 发布于2024-11-15
  • 如何从现有模型自动生成 Sequelize 迁移?
    如何从现有模型自动生成 Sequelize 迁移?
    使用 Sequelize CLI 自动生成迁移为 Sequelize 模型创建迁移是数据库管理中的关键步骤。迁移使您能够跟踪数据库架构随时间的变化。虽然 Sequelize 提供了用于模型生成的 CLI 工具,但它还提供了从现有模型自动生成迁移的功能。要自动生成迁移,请按照以下步骤操作:安装 Seq...
    编程 发布于2024-11-15
  • 如何计算MySQL中两个日期之间的准确年龄差?
    如何计算MySQL中两个日期之间的准确年龄差?
    在 MySQL 中获取两个日期之间的年龄差在 MySQL 中,计算两个日期之间的年龄差可能具有挑战性,尤其是如果你想要它作为一个整数。通常,使用 DATEDIFF() 或除以 365 会导致浮点值或年份可能不准确。一种有效的方法是使用 TIMESTAMPDIFF() 和适当的日期单位:SELECT ...
    编程 发布于2024-11-15
  • 如何将变量中的凭证传递到 AWS 开发工具包版本 2 以进行 IAM 服务访问?
    如何将变量中的凭证传递到 AWS 开发工具包版本 2 以进行 IAM 服务访问?
    将凭证从变量传递到 AWS SDK 版本 2此查询呼应了之前有关使用来自变量的凭证的 AWS SDK 的问题。但是,在本例中,使用的是 SDK 版本 2,它消除了会话功能。要使用从变量获取的凭据建立新客户端以访问 IAM 服务,请考虑以下函数:func getIAMClient(ctx contex...
    编程 发布于2024-11-15

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

Copyright© 2022 湘ICP备2022001581号-3