循环mysqli更新,同时在while循环中变量增加1

时间:2020-09-03 20:48:51

标签: php jquery ajax mysqli

我正在尝试循环这段代码,因为它将动态生成。它从mysql获取行数并循环多次。 POST来自ajax,它也已循环播放,并且可以完美运行。在php部分中,我不确定为什么它不起作用。我已经尝试了很多不同的循环变体。

$queryEle = "SELECT * FROM featureSheetContent WHERE `user_id` = '$userID' AND `feature_id` = '$featureID'";
  $resultEle = mysqli_query($connect,$queryEle);
  $rowEle = mysqli_num_rows($resultEle);

  $i = 1;

  while ($i < $rowEle) {
    $eleID.$i = $_POST['eleID'.$i];
    $eleID .= $eleID.$i;
    $resizeWidth.$i = $_POST['resizeWidth'.$i];
    $resizeWidth .= $eleID.$i;
    $resizeHeight.$i = $_POST['resizeHeight'.$i];
    $resizeHeight .= $eleID.$i;

    $UploadMain = $connect->prepare("UPDATE featureSheetContent SET `ele_width` = ?, `ele_height` = ? WHERE id = ?");
    $UploadMain->bind_param('sss', $resizeWidth, $resizeHeight, $eleID);
    $UploadMain->execute();

    $i++;
  }

未循环的代码有效:

  $eleID1 = $_POST['eleID1'];
  $resizeWidth1 = $_POST['resizeWidth1'];
  $resizeHeight1 = $_POST['resizeHeight1'];
  $eleID2 = $_POST['eleID2'];
  $resizeWidth2 = $_POST['resizeWidth2'];
  $resizeHeight2 = $_POST['resizeHeight2'];

  
  $UploadMain = $connect->prepare("UPDATE featureSheetContent SET `ele_width` = ?, `ele_height` = ? WHERE id = ?");
  $UploadMain->bind_param('sss', $resizeWidth1, $resizeHeight1, $eleID1);
  $UploadMain->execute();
  $UploadMain = $connect->prepare("UPDATE featureSheetContent SET `ele_width` = ?, `ele_height` = ? WHERE id = ?");
  $UploadMain->bind_param('sss', $resizeWidth2, $resizeHeight2, $eleID2);
  $UploadMain->execute();

1 个答案:

答案 0 :(得分:0)

您的变量变量语法错误;正确的语法是${"eleID".$i}。但是,无需在循环中每次使用不同的变量。将UPDATE查询绑定到一组特定的变量,然后从POST变量中重新分配这些变量。

$eleID = $resizeWidth = $resizeHeight = null; // Create the variables before binding
$UploadMain = $connect->prepare("UPDATE featureSheetContent SET `ele_width` = ?, `ele_height` = ? WHERE id = ?");
$UploadMain->bind_param('sss', $resizeWidth, $resizeHeight, $eleID);

for ($i = 1; $i <= $rowEle; $i++) {
    $eleID = $_POST['eleID'.$i];
    $resizeWidth = $_POST['resizeWidth'.$i];
    $resizeHeight = $_POST['resizeHeight'.$i];
    $UploadMain->execute();
}

顺便说一句,您的UPDATE查询将为任何用户更新一行,而不仅仅是user_id = '$userID'。那是故意的吗?

相关问题