0

我尝试在 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());
}
?>

我想提交所有表格。我应该尝试为所有表单创建一个提交按钮,还是有办法单独处理所有表单?

4

1 回答 1

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~ 标识符添加到输入名称中,这样您就可以轻松区分哪个是哪个。

于 2013-08-10T17:24:13.640 回答