php mysql while mysql_fetch_array 为什么只能循环一次 100
$jihe=mysql_query("select*frommg_c_pifa");while($row=mysql_fetch_array($jihe)){$sql=m...
$jihe = mysql_query("select * from mg_c_pifa");
while($row=mysql_fetch_array($jihe)){
$sql = mysql_query("insert into mg_flow_gengxin (contentid) values ($row[contentid])");
}
代码如上,为什么insert into语句只插入了一条数据,应该是插入三条才对,
应该怎么写,忘高手帮忙,万分感谢。 展开
while($row=mysql_fetch_array($jihe)){
$sql = mysql_query("insert into mg_flow_gengxin (contentid) values ($row[contentid])");
}
代码如上,为什么insert into语句只插入了一条数据,应该是插入三条才对,
应该怎么写,忘高手帮忙,万分感谢。 展开
3个回答
展开全部
可以先保存结果集,然后在插入。
$jihe = mysql_query("select * from mg_c_pifa");
$arr = array();
while($row=mysql_fetch_array($jihe)){
array_push($arr,$row);
}
//循环插入
foreach($arr as $value){
.........
}
思路就是这样 着急 可能会有个别语法问题
$jihe = mysql_query("select * from mg_c_pifa");
$arr = array();
while($row=mysql_fetch_array($jihe)){
array_push($arr,$row);
}
//循环插入
foreach($arr as $value){
.........
}
思路就是这样 着急 可能会有个别语法问题
追问
方法也试过,还是不行呢?
追答
那就应该查看你的数据库设计问题了,那就不应该是代码的问题了
展开全部
$jihe = mysql_query("select * from mg_c_pifa");
while($row=mysql_fetch_array($jihe, MYSQL_ASSOC)){
$sql = mysql_query("insert into mg_flow_gengxin (contentid) values ($row[contentid])");
}
while($row=mysql_fetch_array($jihe, MYSQL_ASSOC)){
$sql = mysql_query("insert into mg_flow_gengxin (contentid) values ($row[contentid])");
}
追问
试过,还是只有一条,为什么print_r($row);就可以循环出三条,而插入只有一条?
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
mg_flow_gengxin (contentid) values ($row[contentid])"
你这样写已经限制住了它的字段了呀就插contentid
你这样写已经限制住了它的字段了呀就插contentid
追问
不是插入几个字段值,是应该插入三条数据,不是三个字段。也就是说,现在只循环了一次。
追答
$row<xxxx不是等于把
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询