如何在嵌套循环内停止echo语句多次回显

时间:2015-03-23 22:41:34

标签: php for-loop while-loop nested nested-loops

我有以下查询结构

结构

//note the value in $array isan array sent from the client side script
$q1 = mysqli_query($db,'query stuff')or trigger_error(mysqli_error());
if(mysqli_num_rows($q1) >=1 )
{
    while($row = mysqli_fetch_assoc($query)) // while loop 1
    {
        $q2 = mysqli_query($db,'query stuff') or trigger_error(mysqli_error());
        if(mysqli_num_rows($q2)>=1)
        {
            while($r=mysqli_fetch_assoc($2)) // while loop 2
            {
                for($i=0;$i<sizeof($array);$i++) // forloop
                {
                    if( \\validate conditions )
                    {
                        echo $i;//echoes 0101 instead of 01
                    }
                }
            }
        }
    }
}

说明:上面的代码包含2个while循环和1个for循环.for循环嵌套在一个中,而另一个循环嵌套在另一个while循环中。当我输出代码时,预期输出为01,而是返回0101

如何阻止这种情况发生


我尝试了什么

我尝试过以下结构

            .....
            $tab_exists = false;
            while($r=mysqli_fetch_assoc(q2))//while loop 2
            {
                for($i=0;$i<sizeof($array);$i++) // for loop
                {
                       if(!$tab_exists)
                       {
                           echo $i;//echoes 00 instead of 01
                           $tab_exists = true;
                       }
                }
            }

上述结构的结果:在上面的代码中,语句中的$ i不会递增

1 个答案:

答案 0 :(得分:0)

试试这个:

$q1 = mysqli_query($db,'query stuff')or trigger_error(mysqli_error());
$count =0;
if(mysqli_num_rows($q1) >=1 )
{
    while($row = mysqli_fetch_assoc($query))
    {
        $q2 = mysqli_query($db,'query stuff') or trigger_error(mysqli_error());
        if(mysqli_num_rows($q2)>=1)
        {
            while($r=mysqli_fetch_assoc($2))
            {
                for($i=0;$i<sizeof($array);$i++)
                {
                    if( \\validate conditions && $count<=2)
                    {
                        echo $i;//echoes 0101 instead of 01
                        $count++;
                    }
                }
            }
        }
    }
}