关于这个问题已经提出了很多问题.我已经了解了stackoverflow上给出的一些解决方案,但它们似乎都没有工作.我有一个带有foreach循环的表单,我正在尝试使用其唯一值提交“所选表单”,然后使用该值运行SQL查询.
问题是,提交的文本区域的name属性.首先,查询只会更新循环中的最后一列.然后我尝试了另一种方法.例如,将name属性更改为“someattribute []”.
现在,正在更新查询中的所有选定列.
form.php的
<?php
...................
foreach($stmt as $obj){
$id = $obj['id'];
$likes = $obj['like1'];
echo '<form action="" method="post" enctype="multipart/form-data">';
echo '<input type="hidden" name="lkcv[]" value="'.$id.'">';
echo '<input type="hidden" name="like" value="">';
echo '<input type="image" src="images/like.png" id="lksub" width="15"
value="som" height="15" style="float:right;position:relative;margin-
right:290px;"/><div class="ld">'.$likes.'</div>';
echo '</form>’;
}
?>
query.php
<?php
if (isset($_POST['like'])){
$com_id = $_POST['lkcv'];
for ($i=0; $i<sizeof($com_id);$i++){
# query into db table to know current voting score
$query = mysql_query("SELECT like1 FROM comment WHERE id = '$com_id[$i]'");
# increase or dicrease voting score
if ($data = mysql_fetch_array($query)) {
$like = ++$data['like1'];
# update new voting score
$query2 = mysql_query("UPDATE comment SET like1 = '{$like}' WHERE id = '$com_id[$i]'");
}
}
}
?>
query.php [已解决]
<?php
if( isset( $_POST['lkcv'] ) && is_array( $_POST['lkcv'] ) )
{
$idArray = array();
foreach( $_POST['lkcv'] as $value )
{
$idArray[] = intval( $value );
}
$db->query( "UPDATE comment SET like1 = like1 + 1 WHERE id IN (".implode(
',', $idArray ).")" );
}
?>
注意:一旦我开始工作,我将更新我的查询以使用PDO预处理语句.谢谢你的帮助.
最佳答案 我会在这样的一个查询中执行此操作:
<?php
if( isset( $_POST['lkcv'] ) && is_array( $_POST['lkcv'] ) )
{
$idArray = array();
foreach( $_POST['lkcv'] as $value )
{
$idArray[] = intval( $value );
}
$db->query( "UPDATE comment SET like1 = like + 1 WHERE id IN (".implode( ',', $idArray ).")" );
}