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

本文介绍了PDO连接数据库时遇到‘SQLSTATE[HY000][2002] No such file or directory’错误的解决方案,包括设置pdo_mysql.default_socket和将localhost改为127.0.0.1。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

    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://stackoverflow.com/questions/20723803/pdoexception-sqlstatehy000-2002-no-such-file-or-directory/22927341#22927341 
————————————————
版权声明:本文为优快云博主「啊Joe」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.youkuaiyun.com/joechao1003/article/details/60633271/

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值