4

可能重复:
Windows 平台上的 mysql_connect (localhost / 127.0.0.1)

我刚刚在开发机器上更新了我的 Apache 和 PHP 版本,而 PDO 已经完全崩溃了。

这是死的简单 PDO 类:

class PDO_DBH {
    public static function openSesame() {
        echo '<p>start openSesame: </p>'.microtime(true);
        $db_username = 'root';
        $db_password = 'pass';
        try {
            $dbh = new PDO('mysql:host=localhost;dbname=DB_NAME', $db_username, $db_password);
            $dbh->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION);
            echo '<p>end successful openSesame: </p>'.microtime(true);
            return $dbh;
        } catch (PDOException $e) {
            echo '<p>end failed openSesame: </p>'.microtime(true);
            return 'PDO database access error!';
        }
    }
}

在升级之前,目前在其他开发机器上,一个典型的页面将在一秒钟内加载,最多两个。

现在,通过 的奇迹microtime(true),我看到每个连接打开都需要大约一整秒。

一个典型的页面可能会创建一个新页面$dbh,然后创建$dbh = null;20 次,因为不同的对象和方法会检索它们需要的数据。这在其他机器或我的虚拟主机上从来都不是问题。

我在这里哪里出错了?

4

1 回答 1

4

这只是一个猜测 - 但在 Windows 机器上127.0.0.1改为而不是成功localhost

于 2012-10-30T06:03:08.000 回答