mysql update正在更新所有行而不是一行

时间:2017-05-27 13:58:37

标签: php forms mysqli

我遇到的问题似乎无法弄清楚出了什么问题。我知道SQL注入,但考虑到用户我并不担心。

好的,我的问题是我何时更新。如果我放$update = "UPDATE robert SET req='$reqs' WHERE id='$x'";它什么都不做,如果我放$update = "UPDATE robert SET req='$reqs'";它会更新整个列,这不是我想要的。 这是完整的代码:

<?php
                $i = 0;
                $x = 0;
                $sql = "SELECT * FROM robert";
                $result = mysqli_query($conn, $sql);

                while($row = mysqli_fetch_assoc($result)){
                    echo "<form action='rmcclanahan.php' method='post'>
                    <table><tr>";
                    echo "<td><input type='text' name='date".$i."' value='".$row['date']."' size='8'></td>";
                    echo "<td><input type='text' name='req".$i."' value='".$row['req']."' size='6'></td>";
                    echo "<td><input type='text' name='po".$i."' value='".$row['po']."' size='6'></td>";
                    echo "<td><input type='text' name='requestor".$i."' value='".$row['requestor']."' size='6'></td>";
                    echo "<td><input type='text' name='line".$i."' value='".$row['line']."' size='5'></td>";
                    echo "<td><input type='text' name='description".$i."' value='".$row['description']."' size='12'></td>";
                    echo "<td><input type='text' name='price".$i."' value='".$row['price']."' size='12'></td>";
                    echo "<td><input type='text' name='supplier".$i."' value='".$row['supplier']."' size='6'></td>";
                    echo "<td><input type='text' name='eleven".$i."' value='".$row['eleven']."' size='12'></td>";
                    echo "<td><input type='text' name='carcap".$i."' value='".$row['carcap']."' size='12'></td>";
                    echo "<td><input type='text' name='carnum".$i."' value='".$row['carnum']."' size='6'></td>";
                    echo "<td><input type='text' name='engineering".$i."' value='".$row['engineering']."' size='12'></td>";
                    echo "<td><input type='text' name='costcenter".$i."' value='".$row['costcenter']."' size='6'></td>";
                    echo "<td><input type='text' name='accnum".$i."' value='".$row['accnum']."' size='5'></td>";
                    echo "<td><input type='text' name='recieved".$i."' value='".$row['recieved']."' size='6'></td>";
                    echo "<td><input type='text' name='recdate".$i."' value='".$row['recdate']."' size='8'></td>";
                    echo "<td><button type='submit' name='submit".$i."'>Edit</button></td>";
                    echo "</tr></table>
                    </form>";


                    $i++;
                    $x++;

                    }
                    if(isset($_POST['submit'.$i.''])){
                            $reqs = $_POST['req'.$i.''];
                            $update = "UPDATE robert SET req='$reqs' WHERE id='$x'";
                            $qry = mysqli_query($conn, $update);

                            }

2 个答案:

答案 0 :(得分:2)

查询应该是这样的:

$update = "UPDATE robert SET req='$reqs' WHERE id='{$row['id']}'";

$ X是一个在每次迭代中递增的数字,id可以与$ x

不同

答案 1 :(得分:-2)

在您的代码中,

$update = "UPDATE robert SET req='$reqs' WHERE id='$x'";

而不是这一行只需将其改为this-&gt;

$update = "UPDATE robert SET req= " . $reqs . " WHERE id=" . $x;

你遇到了问题,因为有时它无法获取变量值并解决这个问题只是连接变量并使用它。 我不会检查它,但希望它能起作用。