PHP var_dump返回reesource(16)

时间:2014-02-14 06:23:58

标签: php mysql sql arrays output

我有以下代码:

function fetch_conversation_messages($conversation_id){
    $conversation_id = (int)$conversation_id;

    $sql = "SELECT
                            `conversations_messages`.`message_date`,
                            `conversations_messages`.`message_date` > `conversations_members`.`conversation_last_view` AS `message_unread`,
                            `conversations_messages`.`message_text`,
                            `users`.`user_name`
                    FROM `conversations_messages`
                    INNER JOIN `users` ON `conversations_messages`.`user_id` = `users`.`user_id`
                    INNER JOIN `conversations_members` ON `conversations_messages`.`conversation_id` = `conversations_members`.`conversation_id`
                    WHERE `conversations_messages`.`conversation_id` = {$conversation_id}
                    AND `conversations_members`.`user_id` = {$_SESSION['user_id']}
                    ORDER BY `conversations_messages`.`message_date` DESC";

    $result = mysql_query($sql);
    var_dump($result);
    $messages = array();

    while (($row = mysql_fetch_assoc($result)) !== false){
            $messages[] = array(
                    'date'          => $row['message_date'],
                    'unread'        => $row['message_unread'],
                    'text'          => $row['message_text'],
                    'user_name'     => $row['user_name'],
            );
    }
    var_dump( $messages );

}

应该返回这样的内容:

Array ( [0] => Array ( [date] => 1322254667 [text] => one [user_name] => bob ) )

但是,它会返回

resource(16) of type (mysql result) array(0) { }

我是PHP和MySQL的新手,但我已经尝试检查拼写错误,回显mysql_error,并在出错时终止脚本,这表明SQL中没有错误。

我不知道出了什么问题以及如何解决它。

请帮帮我。提前谢谢。

3 个答案:

答案 0 :(得分:1)

var_dump($result);显示resource(16) of type (mysql result)表示您的查询正常。

var_dump($messages);显示空数组表示查询结果为空。

答案 1 :(得分:0)

当您的查询有效时,

mysql_query函数应返回resource

要查看查询的实际返回结果,请使用行抓取功能,例如mysql_fetch_assocmysql_fetch_object等。在您的情况下,您将获取的值放在 $ row 变量中,因此您可以在其上使用var_dump。

while ($row = mysql_fetch_assoc($result)){
        var_dump($row);
}

尝试检查reference

答案 2 :(得分:0)

对于SELECT,SHOW,DESCRIBE,EXPLAIN和其他返回结果集的语句,mysql_query()成功时返回resource,错误时返回FALSE。

对于其他类型的SQL语句,INSERT,UPDATE,DELETE,DROP等,mysql_query()成功时返回TRUE,错误时返回FALSE。