PHP显示来自数据库的记录

时间:2013-02-25 09:46:21

标签: php mysql database

我正在尝试显示存储在我的数据库中的记录,这是我在PHP上的代码:

<?php
include("includes/connect.php");
$user_id = $_GET['user_id'];
$recipe_id = $_GET['recipe_id'];

$sql_check = "select * from user_favorites where user_id = '$user_id' and recipe_id = '$recipe_id'";
$query_check = mysql_query($sql_check);

$result_array = array();
while ($row = mysql_fetch_assoc($query_check)) {
$user_id = $row["user_id"];
$recipe_id = $row["recipe_id"];

$result_array[]= array("user_id"=> $user_id, "recipe_id"=> $recipe_id);
$json_encoded = json_encode($result_array);
echo "addToCallback(". $json_encoded.")";
}
?>

OUTPUT:addToCallback([{“user_id”:“0”,“recipe_id”:“0”}])

在我的数据库表中,我已经有了存储的记录,但为什么它只显示0?我的桌子上没有“0”输入。我的代码有问题吗?

谢谢!

3 个答案:

答案 0 :(得分:0)

您的代码有3个问题:

  1. 您没有正确格式化查询部分
  2. 您无法检查可能的错误
  3. 您很可能正在编码错误的数组
  4. 第2项至关重要。您始终需要被告知发生了所有错误 - 因此您可以采取适当的措施并解决问题。
    没有错误信息,你就会失明和聋。

    所以,这是一个改进的版本 它将返回编码数据或mysql错误(如果你打开了display_errors。否则将在web-servers error_log中记录错误。)
    如果既没有数据也没有错误消息 - 那么您的查询没有返回任何行。

    <?php
    error_reporting(E_ALL);
    include("includes/connect.php");
    $user_id   = mysql_real_escape_string($_GET['user_id']);
    $recipe_id = mysql_real_escape_string($_GET['recipe_id']);
    
    $sql = "select * from user_favorites where user_id = '$user_id' and recipe_id = '$recipe_id'";
    $res = mysql_query($sql) or trigger_error(mysql_error()."[$sql]");
    
    $data = array();
    while ($row = mysql_fetch_assoc($res)) {
        $data[] = $row;
    }
    $json_encoded = json_encode($result_array);
    echo "addToCallback(". $json_encoded.")";
    

答案 1 :(得分:0)

  1. 确保您获得所有GET值

  2. 更改:

  3. $sql_check = "select * from user_favorites where user_id = '$user_id' and recipe_id = '$recipe_id'";

    到:

    $sql_check = "select * from user_favorites where user_id = '".mysql_real_escape_string($user_id)."' and recipe_id = '".mysql_real_escape_string($recipe_id)."'";

    echo $sql_check并在phpmyadmin中运行并查看输出

答案 2 :(得分:0)

我刚刚测试了您的代码并进行了现有的调用

test.php?user_id = 1&amp; recipe_id = 5

addToCallback([{ “USER_ID”: “1”, “recipe_id”: “5”}])

现有的电话没有回复我:]