0

我很难从一个表单中更新多个表。我已经完成了查询并使用(或死)检查了错误,但似乎我的 MySQL 代码中没有错误。我可以更新主表的数据,但我不能更新另一个表。我怀疑我的表单字段有问题。这是我的表单代码:

<?php

$sql= "SELECT * FROM client WHERE resID=".$_GET["resID"];
$rs = mysql_query($sql) or die($sql."<br/><br/>".mysql_error());

$sqlM= "SELECT * FROM menu WHERE resID=".$_GET["resID"];
$rsM = mysql_query($sqlM) or die($sqlM."<br/><br/>".mysql_error());

$i = 0;


echo '<table width="50%">';
echo '<tr>';
echo '<td>ID</td>';
echo '<td>Name</td>';
echo '<td>Edit</td>';
echo '</tr>';






echo "<form name='form_update' method='post' action='client_admin_post.php'>\n";


$f=mysql_fetch_array($rs);echo '<tr>';
echo "<td>Res ID :</td>";
echo "<td>{$f['resID']}<input type='hidden' name='resID' value='{$f['resID']}' /></td>";
echo '</tr>';
++$i;

echo '<tr>';
echo "<td>Restaurant Name :</td>";
echo "<td><input type='text' size='40' name='resName' value='{$f['resName']}' /></td>";
echo '</tr>';
++$i;


while ($fM = mysql_fetch_array($rsM)) {

echo '<tr>';
echo "<td>Menu :</td>";
echo "<td><input type='text' size='40' name='mname[$i]' value='{$fM['name']}' /></td>";
echo "<td>{$fM['id']}<input type='hidden' name='mid[$i]' value='{$fM['id']}' /></td>";
echo '</tr>';
++$i;
}


echo '<tr>';
echo "<td><input type='submit' value='submit' /></td>";
echo '</tr>';
echo "</form>";
echo '</table>';

?> 

这是我的邮政编码:

<?php


        //session_start();
        include_once("connection.php");

        $resID= $_POST["resID"];
        $resName= $_POST["resName"];

            $sql = "UPDATE client ".
           "SET resName = '$resName' ".
           "WHERE resID = '$resID' " ;

       mysql_query($sql) or die ('query failed:' . mysql_error());

    $size = count($_POST['mname']);

    $i = 0;
    while ($i < $size) {
    $name= $_POST['mname'][$i];
    $id = $_POST['mid'][$i];

    $sqlM = "UPDATE menu SET name = '$name' WHERE id = '$id' LIMIT 1";
    mysql_query($sqlM) or die ("Error in query: $sqlM");
    echo "$name<br /><br /><em>Updated!</em><br /><br />";
    ++$i;
    }

    ?> 

如你们所知,一家餐厅有很多菜单。我可以编辑主要餐厅信息,但无法编辑菜单。请帮我。非常感谢您的帮助。感谢:D

4

1 回答 1

0

在将其输出为 $mname 索引之前,您至少 ++$i 两次。所以 $_POST['mname'] 会有索引 2 .. count_of_rows+1。您的 while() 忽略了这一事实并计算 0 .. 大小。

如果您打开了所有警告(如您所愿),您将收到一条警告,指出在“$name= $_POST...”开始的行上使用了无效索引 0,您将能够从那里找出答案。

于 2012-12-07T08:52:19.133 回答