我正在尝试显示存储在我的数据库中的记录,这是我在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”输入。我的代码有问题吗?
谢谢!
答案 0 :(得分:0)
您的代码有3个问题:
第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)
确保您获得所有GET值
更改:
$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”}])
现有的电话没有回复我:]