0

目标:简单地从 MySQL 数据库中获取数组。

问题:我在 PDO 语句中使用 $dsn“字符串变量”作为参数,但似乎有一个未捕获的异常,它与调用驱动程序或 (PDO->__construct) 有关 - 我不是当然。您对如何修复 $dsn 字符串变量或此代码的其他可能导致其失败的区域有任何想法吗?提前致谢。

// 定义数据库参数

    $dbhost = "localhost";
    $dbname = "x";
    $dbuser = "y";
    $dbpass = "z";

// 调用驱动程序(作为变量字符串)

    $dsn = "mysql:host=$dbhost;dbname=$dbname";

// 连接到新创建的 db 对象

    $dbh = new PDO($dsn, $dbuser, $dbpass);

// 设置 PDO 错误模式以启用异常

    $dbh->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
    $dbh->setAttribute(PDO::ATTR_EMULATE_PREPARES, false);

// 执行对数据库的查询

    $sql = "SELECT * FROM a_aif_remaining";
    $sth = $dbh->prepare($sql);
    $sth->execute();

// 显示查询结果

    print("PDO::FETCH_ASSOC: ");
    print("Return next row as an array indexed by column name");
    $result = $sth->fetch(PDO::FETCH_ASSOC);
    print_r($result);
    print("");
    return $results;

// 关闭数据库连接

    $dbh = NULL;

    ?>
4

2 回答 2

1

将您的代码放在 try catch 块中。并查看报告的错误信息。下面的一个例子:

try
{
  if ( !class_exists( 'PDO' ) )
    throw new Exception( 'PHP without PDO' );
  if ( array_search( PDO::getAvailableDrivers(), 'mysql' ) === false )
    throw new Exception( 'PHP without PDO mysql driver' );
  $dbh = new PDO( ... );
  ...
}
catch ( PDOException $e )
{
  print $e->getMessage();
}
catch ( Exception $e )
{
  print $e->getMessage();
}
于 2012-12-28T02:51:26.203 回答
0

在你寻找它的地方不可能有任何问题。用变量替换字符串是可以的,不会导致任何问题。所以,它在别的地方。幸运的是 PHP 报告了它,但奇怪的是,您并没有太多关注该报告。

似乎有一个未捕获的异常

未捕获的异常通常包含错误消息。
大多数 PHP 错误消息都非常有用。必须通读它们才能得到问题的解释。毕竟,它是您唯一的信息来源。除了服务器本身,没有人能告诉你服务器出了什么问题。如果您在解释错误消息时遇到困难 -必须将其与您的问题一起发布,让人们为您解释它。因此,您收到的每条错误消息都应该完整且完整地发布在您的问题中。简单但非常重要的规则。

于 2012-12-28T05:43:21.893 回答