Несколько форм обрабатываются одним скриптом php

Я пытаюсь создать страницу заказа на php. Я создал форму, которая хранит данные в базе данных. Номер формы зависит от пользователя и создается динамически.

<?php
if(isset($_POST['submit_num']))
{
    $number=$_POST['sky'];

    for($i=0;$i<$number;$i++)
    {
            $item = $_SESSION['item'];

            echo $item;
            $rec_query = "SELECT * FROM ylika";
            $rec_result= mysql_query($rec_query) or die("my eroors");

            echo '<form action="user_order_form.php" method="POST">';
            echo '<html>';
            while($row_rec = mysql_fetch_array($rec_result))
            {
                echo '<input type="checkbox" name="yliko[]" value='.$row_rec['onoma'].'> '.$row_rec['onoma'].'';
                echo '<br>';
            }
            echo '<br>';
            echo '<input type="submit" name="submit" value="ORDER">';
            echo '</form>';

    }

}
?>

Поэтому у меня есть много форм и 1 сценарий для их обработки. Если я отправляю 1 форму, тогда она применяет данные к базе данных, но другие формы исчезают. Это второй php-обработчик.

<?php
if (isset($_POST['submit']))
{   
    $max_id = "SELECT MAX(id_order) FROM id_of_orders";
    $x=mysql_query($max_id) or die("my eroors");
    $id= mysql_fetch_array($x);
    $xyz = $id['MAX(id_order)'];

    $item = $_SESSION['item'];
    $temp = $_POST['yliko'];
    $temp2 = implode(",", $temp);
    $inserts = ("INSERT INTO orders (order_id,product,ulika) VALUES ('$xyz' , '$item','$temp2')");
    $inc_prod=("UPDATE proion SET Counter = Counter + 1 WHERE proion.onomasia='$item'");
    mysql_query($inserts) or die(mysql_error());
    mysql_query($inc_prod) or die(mysql_error());
}
?>

Я хочу отправить все формы. Должен ли я попытаться создать одну кнопку отправки для всех форм или есть способ обработать их все по отдельности?

1 ответ

Решение

Вы можете иметь много форм для отправки, но просто определить одну большую <form> со всеми ними, тогда вы не потеряете никакой информации.

<?php
if(isset($_POST['submit_num']))
{
    $number=$_POST['sky'];

    echo '<form action="user_order_form.php" method="POST">';
    for($i=0;$i<$number;$i++)
    {
            $item = $_SESSION['item'];

            echo $item;
            $rec_query = "SELECT * FROM ylika";
            $rec_result= mysql_query($rec_query) or die("my eroors");

            echo '<html>';
            while($row_rec = mysql_fetch_array($rec_result))
            {
                echo '<input type="checkbox" name="yliko[]" value='.$row_rec['onoma'].'> '.$row_rec['onoma'].'';
                echo '<br>';
            }
            echo '<br>';
            echo '<input type="submit" name="submit" value="ORDER">';

    }
    echo '</form>';

}
?>

теперь вы также можете добавить идентификатор ~$i~ к входным именам, чтобы вы могли легко отличить, какой есть какой.

Другие вопросы по тегам