0

我正在尝试使用此表单更新我的数据库条目:

<form method="post" action="inc/update.php">
    <?php foreach ($links as $row) {
        ?>
        <div class="btn_admin">
            <p>
                <label>Titulo</label>
                <input type="text" name="title[]" value="<?php echo $row["desc"] ?>">
            </p>
            <p>
                <label>Url</label>
                <input type="text" name="url[]" value="<?php echo $row["url"] ?>">
                <input type="hidden" name="id[]" value="<?php echo $row["id"] ?>" />
            </p>

        </div>
    <?php }
    ?>
    <input type="submit" name="submit" value="Update Links" />
</form>

在我的 update.php 文件中:

if ($_SERVER["REQUEST_METHOD"] == "POST"
        && $_POST["submit"] == "Update Links") {

    include_once 'db.php';
    $db = new PDO(DB_INFO, DB_USER, DB_PASS);

    foreach($_POST['id'] as $id ) {

    $title=$_POST["title"][$id-1];
    $url=$_POST["url"][$id-1];

    $sql = "UPATE index_links
                SET desc=?, url=?
                WHERE id=?";
    $stmt = $db->prepare($sql);
    $stmt->execute(array($title, $url, $id-1));
    $stmt->closeCursor();
    }
}

我已经遍历了 $title 和 $url 并且一切都被正确地“抓取”了,但是查询以某种方式失败而没有错误。

我什至尝试弄乱错误的查询语法(如上面示例中的查询 - “UPATE”),没有任何错误……是的,正在访问 foreach 循环。

这似乎是介绍级别的东西,但我看了一个小时左右,没有头脑=吹...我的项目中还有其他查询(不是更新的)运行良好。

4

1 回答 1

6

在您的情况下,查询可能会失败,因为desc它是mySQL 中的保留字。

默认情况下,PDO 可能对其错误消息非常保密。请参阅此问题以了解如何更改。

于 2012-12-20T18:28:55.113 回答