还有什么我需要看到的回复phpinfo()让PDO连接工作?

时间:2013-11-15 16:51:04

标签: php pdo phpinfo

这是我的phpinfo结果的一部分,我可以在那里找到pro?

这个词
PDO
PDO support enabled
PDO drivers mysql

pdo_mysql
PDO Driver for MySQL, client library version    5.0.45
奇怪的是我收到了这个错误:

SQLSTATE[HY000] [2003] Can't connect to MySQL server on 'localhost' (10061)

除此之外,我的配置文件中没有“localhost”。

3 个答案:

答案 0 :(得分:0)

我相信你需要在localhost上运行mysql服务器 或者任何其他要连接的mysql服务器。

在编辑器中使用搜索和替换功能,并删除代码中的所有try .. catch块。它将帮助您找到连接到localhost而不是正确的mysql主机的实际位置。

答案 1 :(得分:0)

您的PHP和pdo已正确安装和配置。

我认为您没有正确设置数据库用户名和密码

官方MySQL网站上提供了更多信息:

http://lists.mysql.com/myodbc/10475

答案 2 :(得分:0)

最后它奏效了。以一种非常奇怪的方式,在我改变了pdo连接语句的属性顺序之后建立了连接。

以下是更改前的连接(我从http://php.net/manual/en/pdo.connections.php开始订购):

try {
    $db = new PDO('mysql:host='.$db_host.';dbname='.$db_name.'', $db_user, $db_pass);
    $db->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
    $db->exec("set names utf8");
} catch(PDOException $e) {
    echo 'ERROR: ' . $e->getMessage();
}

然后我试图改变它的顺序:

try {
    $db = new PDO('mysql:dbname='.$db_name.';host='.$db_host.'', $db_user, $db_pass);
    $db->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
    $db->exec("set names utf8");
} catch(PDOException $e) {
    echo 'ERROR: ' . $e->getMessage();
}

现在它奏效了。我想这个问题来自托管公司。