我有以下查询结构
结构的
//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不会递增
答案 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++;
}
}
}
}
}
}