我有以下查询结构
结构
//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++;
}
}
}
}
}
}