php 批量更新数据,详细见代码
<formname="yfset"method="post"action=""><tablestyle="text-align:center;"width="100%"b...
<form name="yfset" method="post" action="">
<table style="text-align:center;" width="100%" border="0" align="center" cellpadding="3"
<tbody>
<tr><td>编号</td><td>城市</td><td>首重</td><td>续重</td></tr>
<?php
$sql="select * from ·表名· order by yfno";
$row=$empire->query($sql);
while(
$r=mysql_fetch_row($row)){
?>
<tr><td><?php echo $r[0]?></td>
<td><?php echo $r[1]?></td>
<td><input value="<?php $r[0]; ?>" name="no[]" type="hidden" />
<input type="text" name="sz[]" value="<?php echo $r[2]; ?>" /></td>
<td><input type="text" name="xz[]" value="<?php echo $r[3]; ?>" /></td></tr>
<?php } ?>
<tr><td height="25" colspan="4">
<input type="submit" name="sub" value="提交" /></td></tr>
</tbody>
</table>
</form>
<?php
//提交函数
if(!empty ( $_POST['sub'] )){
for($j = 0; $j < count($_POST[no]); $j ++){
mysql_query('update `表名` set `yfsz`=".$_POST[sz][$j].",`yfxz`=".$_POST[xz][$j]." where `yfno`=".intval($_POST[no][$j])" ');
}
//echo "<Script>location.reload();</script>";
}
求问题所在 展开
<table style="text-align:center;" width="100%" border="0" align="center" cellpadding="3"
<tbody>
<tr><td>编号</td><td>城市</td><td>首重</td><td>续重</td></tr>
<?php
$sql="select * from ·表名· order by yfno";
$row=$empire->query($sql);
while(
$r=mysql_fetch_row($row)){
?>
<tr><td><?php echo $r[0]?></td>
<td><?php echo $r[1]?></td>
<td><input value="<?php $r[0]; ?>" name="no[]" type="hidden" />
<input type="text" name="sz[]" value="<?php echo $r[2]; ?>" /></td>
<td><input type="text" name="xz[]" value="<?php echo $r[3]; ?>" /></td></tr>
<?php } ?>
<tr><td height="25" colspan="4">
<input type="submit" name="sub" value="提交" /></td></tr>
</tbody>
</table>
</form>
<?php
//提交函数
if(!empty ( $_POST['sub'] )){
for($j = 0; $j < count($_POST[no]); $j ++){
mysql_query('update `表名` set `yfsz`=".$_POST[sz][$j].",`yfxz`=".$_POST[xz][$j]." where `yfno`=".intval($_POST[no][$j])" ');
}
//echo "<Script>location.reload();</script>";
}
求问题所在 展开
3个回答
展开全部
你先一步步来调试,先输出一个$_POST[no]是不是有值?
然后再看看其他post过来的有没有值?
如果没有值那肯定是错的啦。
然后再看看其他post过来的有没有值?
如果没有值那肯定是错的啦。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
mysql_query('update `表名` set `yfsz`=".$_POST[sz][$j].",`yfxz`=".$_POST[xz][$j]." where `yfno`=".intval($_POST[no][$j])" ');
`yfno`=".intval($_POST[no][$j])这里少了个点"
`yfno`=".intval($_POST[no][$j])这里少了个点"
追问
额。这不是重点。。加上也还是不行。貌似根本取不到post的值,name这要怎么改呢
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
<td><input value="<?php $r[0]; ?>" name="no" type="hidden" />
<input type="text" name="sz" value="<?php echo $r[2]; ?>" /></td>
<td><input type="text" name="xz" value="<?php echo $r[3]; ?>" /></td></tr>
<input type="text" name="sz" value="<?php echo $r[2]; ?>" /></td>
<td><input type="text" name="xz" value="<?php echo $r[3]; ?>" /></td></tr>
追问
表单在循环体中,name值会重复。post取不到
追答
" name="no".$i type="hidden" />
本回答被提问者和网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询