【问题标题】:Uncaught exception 'PDOException' with message 'SQLSTATE[HY000]带有消息“SQLSTATE [HY000]”的未捕获异常“PDOException”
【发布时间】:2012-07-08 05:53:21
【问题描述】:

我转换了以下工作代码:

<?php
    include('config.php');
    $link = mysql_connect($db_host, $username, $password);
    mysql_select_db($db_name);

    $id= $_POST["uniqi"];
    $comments= $_POST["comments"];
    $comments= mysql_real_escape_string($comments);
    $comments = strip_tags($comments);

    $update = "UPDATE mastertable SET comments = '$comments' WHERE id_pk= '$id'";
    mysql_query($update, $link);
    mysql_close();
    header('Location: ccccc.com/pabrowser/… Updated');
?>

到 PDO:

<?php
    $id= $_POST["uniqi"];
    $comments= $_POST["comments"];
    $conn = new PDO("mysql:host=$db_host;dbname=$db_name", $username, $password);

    $sql = "UPDATE mastertable SET comments=?    WHERE id_pk=?";
    $q = $conn->prepare($sql);
    $q->execute(array($comments, $id));

    header('Location: ccccc.com/pabrowser/… Updated');
?>

这给了我

致命错误:未捕获的异常 'PDOException' 带有消息 'SQLSTATE[HY000] [2002] 无法通过 /home 中的套接字'/var/lib/mysql/mysql.sock' (2)' 连接到本地 MySQL 服务器/content/58/9508458/html/pabrowser/comsumcompro.php:4 堆栈跟踪:#0 /home/content/58/9508458/html/pabrowser/comsumcompro.php(4): PDO->__construct('mysql:host =;dbn...', NULL, NULL) #1 {main} 在第 4 行的 /home/content/58/9508458/html/pabrowser/comsumcompro.php 中抛出

【问题讨论】:

  • 您是否在 PDO 部分中包含了 config.php?

标签: php sql pdo


【解决方案1】:

你忘记了include('config.php');

【讨论】:

    【解决方案2】:

    您的 $db_host$db_name 值错误,或者您提供的凭据无效。

    【讨论】:

      【解决方案3】:

      请补充

      include('config.php');
      

      【讨论】:

        【解决方案4】:

        您的连接字符串错误或 MySQL 服务器没有响应。使用try ... catch 构造,如下所示:

        include('config.php');
        
        $id = $_POST["uniqi"];
        $comments = $_POST["comments"];
        try {
            $conn = new PDO("mysql:host=$db_host;dbname=$db_name", $username, $password);
        }
        catch (PDOException $e) {
            echo 'Connection failed: ' . $e->getMessage();
        }
        

        如果您会看到“连接失败”消息,您就明白出了什么问题。

        【讨论】:

        • try 语句不应该和大括号一起使用吗?
        猜你喜欢
        • 2014-11-15
        • 1970-01-01
        • 1970-01-01
        • 2014-03-18
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 2016-09-07
        • 1970-01-01
        相关资源
        最近更新 更多