其他语句的问题


Issue with else statement

>我有下面的代码从数据库中检索行,但是如果我在"assign_id_input"中输入数据库中不存在的 id,它将不会执行 else 语句并显示"错误"。

$assign_id_input = $_POST['assign_id_input'];
$search_assign_user_id = mysql_query("SELECT * FROM free_ebook WHERE useid = $assign_id_input;")or die(mysql_error());
while($assign_user_id_array = mysql_fetch_array($search_assign_user_id, MYSQL_ASSOC)) {
    $filtered_assign_user_id_array = array_filter($assign_user_id_array);
    if(count($filtered_assign_user_id_array) > 0) {
        echo 'No Error';
    }
    else{
        echo 'Error';
    }
}

您的代码没有缩进,并且有点不可读,但在我看来,问题是您在 while 循环中分配。我认为你应该使用它。

while($assign_user_id_array == mysql_fetch_array($search_assign_user_id, MYSQL_ASSOC)) {

在 while 循环之前使用 mysql_affected_rows()

您的错误不会显示,因为您的代码永远不会进入 while 循环,因为 $search_assign_user_id中有 0 行,因此mysql_fetch_array()将返回 FALSE .

您应该与mysql_num_rows()一起检查您的查询是否返回了任何行,然后您可以进入 while 循环。

$assign_id_input = $_POST['assign_id_input'];
$search_assign_user_id = mysql_query("SELECT * FROM free_ebook WHERE userid = $assign_id_input;")or die(mysql_error());
if (mysql_num_rows($search_assign_user_id) > 0) {
    while($assign_user_id_array = mysql_fetch_array($search_assign_user_id, MYSQL_ASSOC)) {
        $filtered_assign_user_id_array = array_filter($assign_user_id_array);
        echo 'No Error';
    }
} else {
    echo 'Error';
}