这是我的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”。
答案 0 :(得分:0)
我相信你需要在localhost上运行mysql服务器 或者任何其他要连接的mysql服务器。
在编辑器中使用搜索和替换功能,并删除代码中的所有try .. catch块。它将帮助您找到连接到localhost而不是正确的mysql主机的实际位置。
答案 1 :(得分:0)
答案 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();
}
现在它奏效了。我想这个问题来自托管公司。