如何在嵌套循环中阻止echo语句多次回显


how to stop echo statement from echoing multiple times while inside 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中,而while循环又嵌套在另一个which循环中。当我输出代码时,预期输出是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不会增加

试试这个:

$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++;
                    }
                }
            }
        }
    }
}