首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >For Loops = Problems中的If语句

For Loops = Problems中的If语句
EN

Stack Overflow用户
提问于 2012-08-22 15:15:50
回答 5查看 89关注 0票数 1

由于某些原因,我的if语句不能像预期的那样工作。

代码语言:javascript
复制
$query = "SELECT title FROM blog";
$result = mysql_query($query);
$rows = mysql_num_rows($result);

for ($j = 0; $j < $rows; ++$j)
{
    if (isset($_POST['$j']))
    {
        $id  = mysql_real_escape_string($_POST['id']);
        $query = "DELETE FROM blog WHERE id='$id'";
        mysql_query($query);
        echo 'Deleted post.. ';
        echo '<a href="blog.php">Click here</a>';
    }
    else
    {
        echo 'Failed!';
    }
}

发生的事情是“删除帖子..”这个"link“与我的表格博客中的行数相呼应。不过,我的表中只有一行被删除,这正是我想要的。每次都会按下一个按钮,所以它不应该回放"Deleted post..“只有一次,“失败了!”剩下的时间呢?谢谢=)

注意:我还是个编程新手,如果这个问题很愚蠢,我很抱歉。

注2:我在另一个页面上有许多按钮。它们用数字'1,2,3‘等来标记。

EN

回答 5

Stack Overflow用户

回答已采纳

发布于 2012-08-22 15:18:47

更改:

代码语言:javascript
复制
$_POST['$j'] // here, due to the single quotes you're
             // always testing for the literal `$j`, and not
             // the value of current loop iteration.

至:

代码语言:javascript
复制
$_POST[$j]
票数 2
EN

Stack Overflow用户

发布于 2012-08-22 15:18:39

变量不是用单引号来解析的,你需要使用双引号。isset($_POST["$j"]

此外,您还试图在循环中一次又一次地删除相同的记录,检查是否设置了$_POST["$j"],但使用的是$_POST['id']

票数 1
EN

Stack Overflow用户

发布于 2012-08-22 15:21:36

尝尝这个

代码语言:javascript
复制
<?php
    $query = "SELECT title FROM blog";
    $result = mysql_query($query);
    $rows = mysql_num_rows($result);

    for ($j = 0; $j < $rows; ++$j)
    {
        if (isset($_POST[$j]))
        {
            $id  = mysql_real_escape_string($_POST['id']);
            $query = "DELETE FROM blog WHERE id='" .$id ."'";
            mysql_query($query);
            echo 'Deleted post.. ';
            echo '<a href="blog.php">Click here</a>';
        }
        else
        {
            echo 'Failed!';
        }
    }

?>
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/12068041

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档