复选框不是针对每一行

时间:2019-06-27 09:59:44

标签: php database checkbox

我有一个1624个项目的列表,您可以选择一个复选框,但是在表单中,它只能检测到622个第一个项目的“打开”状态。如果在下面选中了行,则不会返回“ on”。

我显示了数据库中的碎片列表,您可以通过复选框选择碎片,然后更新数据库。它适用于列表顶部的所有项目,但从一行开始,如果选中该框,则不会在php表单中检测到它。无论作品的顺序如何,它仅适用于622个首件作品。我不知道问题出在哪里,因为我认为它不是来自变量。我想知道这是否是时间执行问题,或者,默认情况下,它是否停止从某一行查找。

我已经准备好验证算法是否检查了每一行,并且所有变量都正确。

  $cpt = 1;
  $id_asm = (isset($_GET['id'])) ? $_GET['id'] : "";
  $SQLQuery2="(select * FROM pieces";
  $SQLResult2 = mysqli_query($MySqliConn, $SQLQuery2);
  $_html_tbStock .= '<tr>';
  // [...other information for the list...]

  while ($row2 = mysqli_fetch_array($SQLResult2, MYSQLI_ASSOC)) {            
      $idpiece = $row2['ID_PIECE'];
      $SQLQuery4 = "SELECT * from parametrage_envoi_stock where ID_ASM = '". $id_asm . "' AND ID_PIECE ='". $idpiece ."'";
      $SQLResult4 = mysqli_query($MySqliConn, $SQLQuery4);
      $row4 = mysqli_fetch_array($SQLResult4, MYSQLI_ASSOC);
      $pointee = ($row4['COCHE'] != 0) ? 'checked="checked"' : ''
      //if the piece was checked before, it is checked by default in the display, else it is not

      $_html_tbStock .= '<td><input id="parametrage_' . $cpt . '" name="parametrage_' . $cpt . '" type="checkbox" ' . $pointee . '/></td>';
      $_html_tbStock .= '</tr>';
    $cpt++;

    }

在表格中,我们得到了:

 $totalpiece = 1624
 $cpt = 1;
 while ($cpt <= $totalpiece) {
   if (isset($_POST['parametrage_' . $cpt])) {
        $ref = $_POST['ref_' . $cpt];
        $rev = $_POST['rev_' . $cpt];
        $nom = $_POST['nom_' . $cpt];
        var_dump($ref);
        var_dump($rev);
        var_dump($nom);

        $SQLQuery2 = "SELECT * FROM pieces WHERE REF_PIECE LIKE '%". $ref ."%' AND REV_PIECE LIKE '%". $rev ."%' AND NOM_PIECE LIKE '%". $nom ."%'";
        $SQLResult2 = mysqli_query($MySqliConn, $SQLQuery2) or die('Erreur2<br />' . mysqli_error($MySqliConn));
        $cnt = 1;
        while ($row2 = mysqli_fetch_array($SQLResult2, MYSQLI_ASSOC)) {
            $id_piece = $row2['ID_PIECE'];
            $SQLQuery2 = "INSERT INTO parametrage_envoi_stock (ID_ASM, ID_PIECE,COCHE) VALUES ('$idasm','$id_piece','1')";
            mysqli_query($MySqliConn, $SQLQuery2) or die('Erreur 1<br />' . mysqli_error($MySqliConn));
            var_dump($SQLQuery2);
            $cnt++;
        }
     }

    }

显示带有所有项目和复选框的列表。我们可以单击所需的所有复选框。

1 个答案:

答案 0 :(得分:1)

尝试检查并更改php ini设置: max_input_vars

更多信息,请参见此处:

https://www.php.net/manual/en/info.configuration.php#ini.max-input-vars

您还可以在php.ini和.htaccess文件中进行更改