javascript - 一种表单中有多个按钮,每个按钮都应该能够更新数据库

标签 javascript php mysql jquery

嗨, friend 们,请告诉我哪里错了,因为即使更新查询成功执行,数据库仍然没有改变 谢谢

这是表单代码

echo'<form action="processor.php" method="post" id ="post_form">';
echo '<input type="hidden" name= "status" id="status" value="">';
$upload_arr=array("1");
foreach($upload_arr as $upload_id)
{
    echo '<input type="button" name="accept-<?=$upload_id?>"   value="accept"             onclick="submit_this(this.name)"/><br>';
    echo    '<input type="button" name="reject-<?=$upload_id?>"  value="reject"  onclick="submit_this(this.name)"/><br>';
    echo    '<input type="button" name="saccept-<?=$upload_id?>"   value="saccept" onclick="submit_this(this.name)"/><br>';
    echo    '<input type="button" name="sreject-<?=$upload_id?>"   value="sreject"       onclick="submit_this(this.name)"/><br>';
 }
echo '</form>';

注意:这里我使用了 $upload_id 一个具有 row[upload id] 的 php 变量,即对于第一个图像,它就像accept 1,reject1,saccept1 和 sreject1 ,对于第二个图像,它是accept2reject2等等

现在是processor.php的代码

$status_pass = isset($_POST['status'])?$_POST['status']:NULL;
if(!empty($status_pass)){
$status_arr = explode('-', $status_pass);
$action  = $status_arr[0];
$upload_id = $status_arr[1];

if($action == 'accept'){
    $status = 1;
}
if($action == 'reject'){
    $status = 2;
}
if($action == 'saccept'){
    $status = 3;
}
if($action == 'sreject'){
    $status = 4;
}
echo $status;
$sql="UPDATE upload SET status='$status' where upload_id = '$upload_id' ";
echo "update success";
 $result = mysql_query("$sql") or die("Invalid query: " . mysql_error());

}

最佳答案

在您的表单中

<form action="processor.php" method="post" id ='post_form'>
  <input type="hidden" name= "status" id="status" value="">
  <?php
    foreach($upload_arr as $upload_id){
  ?>
      <input type="button" name="accept-<?=$upload_id?>"   value="accept" onclick='submit_this(this.name);'/><br>
      <input type="button" name="reject-<?=$upload_id?>"  value="reject" onclick='submit_this(this.name);'/><br>
      <input type="button" name="saccept-<?=$upload_id?>"   value="saccept" onclick='submit_this(this.name);'/><br>
      <input type="button" name="sreject-<?=$upload_id?>"   value="sreject" onclick='submit_this(this.name);'/><br>
  <?php
    }
  ?>
</form>
<script>
function submit_this(name){
    document.getElementById('status').value = name;
    document.getElementById('post_form').submit();
}
</script>

在你的 php 文件中

<?php
$status_pass = isset($_POST['status'])?$_POST['status']:NULL;

if(!empty($status_pass)){
    $status_arr = explode('-', $status_pass);
    $action  = $status_arr[0];
    $upload_id = $status_arr[1];

    if($action == 'accept'){
        $status = 1;
    }
    if($action == 'reject'){
        $status = 2;
    }
    if($action == 'saccept'){
        $status = 3;
    }
    if($action == 'sreject'){
        $status = 4;
    }

    $sql="UPDATE upload SET status='$status' where upload_id = '$upload_id' ";
    //execute sql here
}


?>

关于javascript - 一种表单中有多个按钮,每个按钮都应该能够更新数据库,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19241016/

相关文章:

javascript - 更改受正则表达式影响的字符串中 URL 的颜色

javascript - 使用 JavaScript 进行日期和时间字符串操作

javascript - 如何在 html 搜索方法期间修复列大小?

php.net 的 PHP 开始标签

php - 在对象内部调用对象方法的语法

java - 检索列具有相同值的不同行并通过没有游标超时进行迭代?

php - 哪种方法更好地验证用户凭据?

Javascript根据类名中的数字动态设置宽度

php - 上传并插入xls文件到mysql?

php - 使用数据库中的值进行计算