PDO连接数据库报错:SQLSTATE[HY000] [2002] No such file or directory

 

 

 

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/JoeChao1003/article/details/60633271

    PDO连接数据库报错:“SQLSTATE[HY000] [2002] No such file or directory”。

    出现这个问题的原因是PDO无法找到mysql.sock或者mysqld.sock。

    解决方法1:找到相应的.sock文件,并设置php.ini文件中的pdo_mysql.default_socket的值为.sock文件的路径。

pdo_mysql.default_socket= /tmp/mysqld.sock

然后重启Apache,或者nginx下重启php-fpm即可。

 

    解决方法2:(我是用这种方法解决,简单省力)

    将PDO连接中的dsn的host由“localhost”改为“127.0.0.1”即可

 

<?php
	header("Content-Type=text/html;charset=utf8");
	$dbType   = 'mysql';
	$host     = '127.0.0.1'; //此处不用localhost
	$dbName   = 'joe';
	$userName = 'root';
	$pwd      = '';

	$dsn = "$dbType:host=$host;dbname=$dbName";
	try {
		$pdo = new PDO($dsn, $userName, $pwd);
		echo '连接成功';
	} catch (PDOException $e) {
		echo '连接失败:' . $e->getMessage();
	}
?>

    参考:http://*.com/questions/20723803/pdoexception-sqlstatehy000-2002-no-such-file-or-directory/22927341#22927341

上一篇:学习笔记208—python 读取matlab 中元组(cell)文件


下一篇:【杂记随笔】bash: no such file or directory