2

我最近了解了 PDO,所以我更改了我的 php 文件以适应格式,现在我收到了这个回复:

ERROR: SQLSTATE[HY000] [2002] php_network_getaddresses: getaddrinfo failed: Name or service not known

我没有更改连接变量,只是更改了适合 PDO 的格式。我正在运行 Bitnami Lampstack (5.3.16-0) 并按照文档中的说明操作,在 php.ini 文件中使用 mysql 取消注释 PDO 行。我想知道它是否与我的大小为 0 的 mysql.sock 文件有关。

我的 PDO 连接看起来像这样(我添加了 unix_socket 和端口部分,因为在与此错误相关的另一个问题中提到了它们,但它们似乎没有帮助):

$dbConnection = new PDO('mysql:unix_socket=/opt/lampstack-5.3.16-0/mysql/tmp/mysql.sock;host=$dbhost;port=3306;dbname=$dbname;', $user, $pass);

apache、mysql、httpd 等都在我的服务器上运行良好,这只是在启用 PDO 后出现的。

4

2 回答 2

5

首先,您的示例中的连接字符串是单引号,因此变量替换不起作用。如果您打算使用变量 $dbhost 的内容,请使用双引号。

其次,您不应同时指定本地套接字和主机/端口。选择一个或另一个。我从你的帖子中猜测套接字不是最初的意图。

试试这个:

 $dbConnection = new PDO("mysql:host=$dbhost;port=3306;dbname=$dbhost", $user, $pass);

此外,您的示例将 dbname 指向 $dbhost 变量。这是一个错字吗?

套接字都是 0 字节。它们只是可以读取和写入的命名管道,但它们本身没有内容。如果您想使用它,只需验证套接字是否存在。

祝你好运!

于 2012-11-20T03:21:21.093 回答
0

"mysql:host='localhost';dbname='data';charset=utf8" 你的 DSN 格式错误,它不应该有那些引号。这是正确的格式

//$con=new PDO($dsn, $user, $password); $con=new PDO('mysql:dbname=testdb;host=127.0.0.1','root','');

于 2015-05-17T07:27:11.847 回答