php使用while循环赋值给数组
$lp=mysql_query("SELECT*FROMzpwheresID=$row[ID]");$lp_num=mysql_num_rows($lp);while($...
$lp=mysql_query("SELECT * FROM zp where sID=$row[ID]");
$lp_num=mysql_num_rows($lp);
while($row = mysql_fetch_array($lp))
{
$lp_xm[]=$row[xm];$lp_birth[]=$row[birth];$lp_dead[]=$row[dead];$lp_ID[]=$row[ID];
$q=0;
$en_num=0;
while($q<$lp_num)
{
$en=mysql_query("SELECT * FROM zp where sID=$lp_ID[$q]");
$en_num=mysql_num_rows($en)+$en_num;
while($row = mysql_fetch_array($en))
{
$en_xm[]=$row[xm];$en_birth[]=$row[birth];$en_dead[]=$row[dead];$en_ID[]=$row[ID];
}
echo "$en_num\n";
$q++;
}
}
输出$en_xm的时候,重复出现前面的记录,也就是显示出现问题,比如说显示1、2、3是第一$q得出的记录,4、6、9是第二$q得出的结果,在输出显示的时候,上面显示是这样的:1、2、3、1、2、3、4、6、9。现在不想重复出现1、2、3、也就是每一个记录只显示一遍,有什么方法吗? 展开
$lp_num=mysql_num_rows($lp);
while($row = mysql_fetch_array($lp))
{
$lp_xm[]=$row[xm];$lp_birth[]=$row[birth];$lp_dead[]=$row[dead];$lp_ID[]=$row[ID];
$q=0;
$en_num=0;
while($q<$lp_num)
{
$en=mysql_query("SELECT * FROM zp where sID=$lp_ID[$q]");
$en_num=mysql_num_rows($en)+$en_num;
while($row = mysql_fetch_array($en))
{
$en_xm[]=$row[xm];$en_birth[]=$row[birth];$en_dead[]=$row[dead];$en_ID[]=$row[ID];
}
echo "$en_num\n";
$q++;
}
}
输出$en_xm的时候,重复出现前面的记录,也就是显示出现问题,比如说显示1、2、3是第一$q得出的记录,4、6、9是第二$q得出的结果,在输出显示的时候,上面显示是这样的:1、2、3、1、2、3、4、6、9。现在不想重复出现1、2、3、也就是每一个记录只显示一遍,有什么方法吗? 展开
2个回答
展开全部
先问你几点有关你这个代码的问题,不然我没办法回答,问题都在后面的注释处
$lp=mysql_query("SELECT * FROM zp where sID=$row[ID]");
//该查询中$row[ID]怎么来的,$row[ID]是在后面的循环体中定义的,这里走来就出现不出错吗
$lp_num=mysql_num_rows($lp);
while($row = mysql_fetch_array($lp))
{
$lp_xm[]=$row[xm];$lp_birth[]=$row[birth];$lp_dead[]=$row[dead];$lp_ID[]=$row[ID];
$q=0;
$en_num=0;
while($q<$lp_num)
{
$en=mysql_query("SELECT * FROM zp where sID=$lp_ID[$q]");//执行查询b
$en_num=mysql_num_rows($en)+$en_num;
//上面的值 $en_num应该等于数据行数X(1+2+3+4+5+...+总行数$lp_num),但是这一步是想做什么呢,不理解
while($row = mysql_fetch_array($en))
{
$en_xm[]=$row[xm];$en_birth[]=$row[birth];$en_dead[]=$row[dead];$en_ID[]=$row[ID];
}
echo "$en_num\n";
//问题中的不是说 输出$en_xm吗,怎么输出的是$en_num
$q++;
}
}
$lp=mysql_query("SELECT * FROM zp where sID=$row[ID]");
//该查询中$row[ID]怎么来的,$row[ID]是在后面的循环体中定义的,这里走来就出现不出错吗
$lp_num=mysql_num_rows($lp);
while($row = mysql_fetch_array($lp))
{
$lp_xm[]=$row[xm];$lp_birth[]=$row[birth];$lp_dead[]=$row[dead];$lp_ID[]=$row[ID];
$q=0;
$en_num=0;
while($q<$lp_num)
{
$en=mysql_query("SELECT * FROM zp where sID=$lp_ID[$q]");//执行查询b
$en_num=mysql_num_rows($en)+$en_num;
//上面的值 $en_num应该等于数据行数X(1+2+3+4+5+...+总行数$lp_num),但是这一步是想做什么呢,不理解
while($row = mysql_fetch_array($en))
{
$en_xm[]=$row[xm];$en_birth[]=$row[birth];$en_dead[]=$row[dead];$en_ID[]=$row[ID];
}
echo "$en_num\n";
//问题中的不是说 输出$en_xm吗,怎么输出的是$en_num
$q++;
}
}
展开全部
<?php
$lp=mysql_query("SELECT * FROM zp where sID=$row[ID]");
$q=0;
$lp_num=mysql_num_rows($lp);
while($row = mysql_fetch_array($lp))
{
$lp_xm[]=$row[xm];
$lp_birth[]=$row[birth];
$lp_dead[]=$row[dead];
$lp_ID[]=$row[ID];
$en_num=0;
while($q<$lp_num)
{
$en=mysql_query("SELECT * FROM zp where sID=$lp_ID[$q]");
$en_num=mysql_num_rows($en)+$en_num;
while($row = mysql_fetch_array($en))
{
$en_xm[]=$row[xm];$en_birth[]=$row[birth];$en_dead[]=$row[dead];$en_ID[]=$row[ID];
}
echo "$en_num\n";
$q++;
}
}
?>
$lp=mysql_query("SELECT * FROM zp where sID=$row[ID]");
$q=0;
$lp_num=mysql_num_rows($lp);
while($row = mysql_fetch_array($lp))
{
$lp_xm[]=$row[xm];
$lp_birth[]=$row[birth];
$lp_dead[]=$row[dead];
$lp_ID[]=$row[ID];
$en_num=0;
while($q<$lp_num)
{
$en=mysql_query("SELECT * FROM zp where sID=$lp_ID[$q]");
$en_num=mysql_num_rows($en)+$en_num;
while($row = mysql_fetch_array($en))
{
$en_xm[]=$row[xm];$en_birth[]=$row[birth];$en_dead[]=$row[dead];$en_ID[]=$row[ID];
}
echo "$en_num\n";
$q++;
}
}
?>
追问
似乎只是改了一下$q=0;的位置,程序报错还是一样的。
Warning: mysql_num_rows(): supplied argument is not a valid MySQL result resource in F:\APMServ5.2.6\www\htdocs\zp\sou.php on line 13
Warning: mysql_fetch_array(): supplied argument is not a valid MySQL result resource in F:\APMServ5.2.6\www\htdocs\zp\sou.php on line 14
追答
这句就是你的SQL有问题了,把你的上去了语句打出来看看
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询