由一个脚本php处理的多个表单

时间:2013-08-10 17:17:16

标签: php multiple-forms

我尝试在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 个答案:

答案 0 :(得分:0)

您可以拥有多个提交表单,但只需定义一个大<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~dentifier添加到输入名称中,这样你就可以轻松区分哪个是。