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

来源:互联网 发布:c语言从入门到精通怎样 编辑:程序博客网 时间:2024/05/17 01:26
PDO连接数据库报错:“SQLSTATE[HY000] [2002] No such file or directory”。

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

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

  1. pdo_mysql.default_socket= /tmp/mysqld.sock  
然后重启Apache,或者nginx下重启php-fpm即可。

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

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

[php]
  1. <?php  
  2.     header("Content-Type=text/html;charset=utf8");  
  3.     $dbType   = 'mysql';  
  4.     $host     = '127.0.0.1'//此处不用localhost  
  5.     $dbName   = 'joe';  
  6.     $userName = 'root';  
  7.     $pwd      = '';  
  8.   
  9.     $dsn = "$dbType:host=$host;dbname=$dbName";  
  10.     try {  
  11.         $pdo = new PDO($dsn$userName$pwd);  
  12.         echo '连接成功';  
  13.     } catch (PDOException $e) {  
  14.         echo '连接失败:' . $e->getMessage();  
  15.     }  
  16. ?>  
    参考:http://stackoverflow.com/questions/20723803/pdoexception-sqlstatehy000-2002-no-such-file-or-directory/22927341#22927341
阅读全文
0 0
原创粉丝点击