当前位置: 首页 > 面试题库 >

如何处理PDO异常

法和硕
2023-03-14
问题内容

这个问题已经在这里有了答案

我的PDO声明无效 (1个答案)

4年前关闭。

我正在尝试PDO在php上使用类,但是在查找正确的错误处理方式时遇到了一些麻烦,我编写了以下代码:

<?php
// $connection alreay created on a class which works with similar UPDATE statements
// I've simply added here trim() and PDO::PARAM... data type


$id = 33;
$name = "Mario Bros.";
$url = "http://nintendo.com";
$country = "jp";


try {

$sql = "UPDATE table_users SET name = :name, url = :url, country = :country WHERE user_id = :user_id";

$statement = $connection->prepare ($sql);

$statement->bindParam (':user_id', trim($id), PDO::PARAM_INT);
$statement->bindParam (':name', trim($name), PDO::PARAM_STR);
$statement->bindParam (':url', trim($url), PDO::PARAM_STR);
$statement->bindParam (':country', trim($country), PDO::PARAM_STR, 2);

$status = $statement->execute ();

} catch (PDOException $e) {
    print $e->getMessage ();
}

print $status; // it returns a null value, and no errors are reported

?>

这部分代码不报告错误,但根本不起作用,$status底部的var 返回空值。

有人可以帮我找到我错了吗?


问题答案:

除非您告知,否则PDO不会引发异常。你跑了吗:

$connection->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);

在PDO对象上?



 类似资料:
  • 问题内容: 我们正在进行有关如何处理REST异常的持续讨论。 响应内容类型:JSON 我们有两种解决方案: 将所有未检查的异常作为JSON响应抛出。 发送请求无效响应代码。 参数: 当出现错误时,为什么要返回JSON?只需发送无效的响应码即可。 相反的观点: 对于普通开发人员而言,响应代码的技术性太强。 你怎么说? 问题答案: 对于JSON API,我最近开发了两者。我总是使用有效的JSON进行响

  • PDO 事务处理 PDO 事务对象方法 方法 描述 beginTransaction() 启动一个事务 commit() 提交一个事务 rollBack() 回滚一个事务 inTransaction() 检测是否在一个事务内 注意:当需要使用事务的时候,数据库表引擎不能是 MyISAM ,必须要是 InnoDB。 <?php try { $host = 'mysql:host=local

  • 我在我的项目中使用Log4j 2将儿子日志写入数据库表。这些事件是基于某些MDC密钥/值对来标识的。我关心的是这个appender可以从其append方法中抛出的未经检查的LoggingExcture。这些数据库日志是在异步事务进程中生成的,我不希望主进程受到appender引发的潜在异常的影响。我应该怎么照顾它?我应该将基于配置的appender移动到自定义appender吗?在日志事件追加错误

  • 在我的项目中,我有这样的内容: 我不明白的是如何处理最后一个方法抛出的异常。我希望将异常传播到ParallelFlux之外。有可能吗?正确的处理方式是什么?

  • 由于预设审批人退出企业,导致模版自动停用时,可以在“异常处理”页面进行相应操作。

  • 我们正在将Oracle Weblogic server 8.1升级到Weblogic server 12c,并将java 1.4升级到1.8 我的任务是确保应用程序功能保持不变。一些应用程序自2007年以来就没有碰过。 前面的代码是: 搜索“weblogic.jar”(在“\Oracle\Middleware\Oracle\u Home\wlserver\server\lib”中找到),我看到它没